結果
問題 | No.52 よくある文字列の問題 |
ユーザー |
![]() |
提出日時 | 2018-10-31 00:12:14 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 145 ms / 5,000 ms |
コード長 | 799 bytes |
コンパイル時間 | 2,412 ms |
コンパイル使用メモリ | 82,460 KB |
実行使用メモリ | 54,424 KB |
最終ジャッジ日時 | 2024-09-22 05:37:34 |
合計ジャッジ時間 | 4,561 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 11 |
ソースコード
import java.util.ArrayDeque; import java.util.Arrays; import java.util.Deque; import java.util.HashSet; import java.util.Scanner; import java.util.Set; public class Main { @SuppressWarnings("resource") public static void main(String args[]) { Scanner scanner = new Scanner(System.in); String s[]=scanner.next().split(""); Deque<String>que=new ArrayDeque<>(); que.addAll(Arrays.asList(s)); dfs("",que); System.out.println(set.size()); } static Set<String>set=new HashSet<>(); private static void dfs(String string, Deque<String> que) { if(que.isEmpty()) { set.add(string); return; } Deque<String>que1=new ArrayDeque<>(que); Deque<String>que2=new ArrayDeque<>(que); String t=string+que1.pop(); String c=string+que2.removeLast(); dfs(t,que1); dfs(c,que2); } }