結果
| 問題 | No.52 よくある文字列の問題 | 
| コンテスト | |
| ユーザー |  hhgfhn1 | 
| 提出日時 | 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);
	}
}
            
            
            
        