結果
問題 |
No.204 ゴールデン・ウィーク(2)
|
ユーザー |
![]() |
提出日時 | 2015-06-20 01:33:28 |
言語 | Java (openjdk 23) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,142 bytes |
コンパイル時間 | 2,497 ms |
コンパイル使用メモリ | 78,376 KB |
実行使用メモリ | 41,556 KB |
最終ジャッジ日時 | 2024-10-13 13:25:08 |
合計ジャッジ時間 | 9,255 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 WA * 25 |
ソースコード
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 < SIZE - D; d++){ boolean[] new_days = new boolean[SIZE]; System.arraycopy(days, 0, new_days, 0, SIZE); for(int i = 0; i < D; i++){ new_days[d + i] = true; } int prev = -1; for(int cur = 0; cur < SIZE; cur++){ if(!new_days[cur] && prev >= 0){ max = Math.max(max, cur - prev); prev = -1; }else if(new_days[cur] && prev < 0){ prev = cur; } } if(prev >= 0){ max = Math.max(max, SIZE - prev); } } System.out.println(max); } }