結果
問題 |
No.204 ゴールデン・ウィーク(2)
|
ユーザー |
![]() |
提出日時 | 2015-06-20 02:01:14 |
言語 | Java (openjdk 23) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,304 bytes |
コンパイル時間 | 2,054 ms |
コンパイル使用メモリ | 78,188 KB |
実行使用メモリ | 41,400 KB |
最終ジャッジ日時 | 2024-10-13 13:25:33 |
合計ジャッジ時間 | 9,011 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 35 WA * 11 |
ソースコード
import java.util.ArrayList; import java.util.Arrays; import java.util.HashSet; import java.util.LinkedHashMap; import java.util.LinkedList; import java.util.Scanner; import java.util.Set; import java.util.TreeSet; public class Main { public static final int SIZE = 14; public static void main(String[] args){ Scanner sc = new Scanner(System.in); final int D = sc.nextInt(); boolean[] days = new boolean[SIZE]; for(int i = 0; i < 2; i++){ char[] inputs = sc.next().toCharArray(); for(int j = 0; j < SIZE / 2; j++){ days[i * (SIZE / 2) + j] = inputs[j] == 'o'; } } int max = 0; for(int d = 0; d <= 3 * SIZE - D; d++){ boolean[] new_days = new boolean[3 * SIZE]; System.arraycopy(days, 0, new_days, SIZE, SIZE); for(int i = 0; i < D; i++){ new_days[d + i] = true; } /* for(int i = 0; i < SIZE; i++){ System.out.print(new_days[i] ? "o" : "x"); } System.out.println(); */ int prev = -1; for(int cur = 0; cur < new_days.length; cur++){ if(!new_days[cur] && prev >= 0){ max = Math.max(max, cur - prev); prev = -1; } if(new_days[cur] && prev < 0){ prev = cur; } } if(prev >= 0){ max = Math.max(max, new_days.length - prev); } } System.out.println(max); } }