結果
問題 | No.233 めぐるはめぐる (3) |
ユーザー | kou6839 |
提出日時 | 2015-07-20 15:28:14 |
言語 | Java21 (openjdk 21) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,233 bytes |
コンパイル時間 | 2,156 ms |
コンパイル使用メモリ | 82,956 KB |
実行使用メモリ | 91,012 KB |
最終ジャッジ日時 | 2024-07-08 11:16:14 |
合計ジャッジ時間 | 8,349 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 781 ms
74,052 KB |
testcase_01 | AC | 565 ms
56,628 KB |
testcase_02 | AC | 461 ms
52,316 KB |
testcase_03 | AC | 555 ms
57,268 KB |
testcase_04 | TLE | - |
testcase_05 | -- | - |
testcase_06 | -- | - |
testcase_07 | -- | - |
testcase_08 | -- | - |
testcase_09 | -- | - |
testcase_10 | -- | - |
testcase_11 | -- | - |
testcase_12 | -- | - |
testcase_13 | -- | - |
ソースコード
import java.util.*; public class Main { static HashSet<String> set; static boolean is_boin (char a){ if(a=='a'||a=='i'||a=='u'||a=='e'||a=='o') return true; return false; } static boolean check(String a){ if( a.length()==11){ char last_char = a.charAt(10); if(!is_boin(last_char)){ return false; }} for(int i=0;i<a.length()-1;i++){ if(!is_boin(a.charAt(i)) && !is_boin(a.charAt(i+1))){ return false; } } return true; } static char[] moji = {'i','n','a','b','a','m','e','g','u','r','u'};//11moji static void func(String now,int used){ if(Integer.bitCount(used)==11){ if(!set.contains(now) && check(now)){ System.out.println(now); System.exit(0); }else{ return; } } for(int i=0;i<11;i++){ if((used >> i & 1) == 0){ if(!check(now+moji[i])) continue; StringBuilder aa = new StringBuilder(now+moji[i]); used+=1<<i; func(aa.toString(), used); now = aa.deleteCharAt(aa.length()-1).toString(); used-=1<<i; } } } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int N = sc.nextInt(); set = new HashSet<>(); for(int i=0;i<N;i++)set.add(sc.next()); func("", 0); System.out.println("NO"); } }