結果
| 問題 |
No.871 かえるのうた
|
| コンテスト | |
| ユーザー |
tenten
|
| 提出日時 | 2021-03-16 10:32:09 |
| 言語 | Java (openjdk 23) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,427 bytes |
| コンパイル時間 | 2,950 ms |
| コンパイル使用メモリ | 77,568 KB |
| 実行使用メモリ | 65,852 KB |
| 最終ジャッジ日時 | 2024-11-07 21:06:32 |
| 合計ジャッジ時間 | 13,346 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 41 WA * 8 |
ソースコード
import java.util.*;
import java.io.*;
public class Main {
public static void main (String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] first = br.readLine().split(" ", 2);
int n = Integer.parseInt(first[0]);
int k = Integer.parseInt(first[1]) - 1;
String[] second = br.readLine().split(" ", n);
String[] third = br.readLine().split(" ", n);
Frog[] frogs = new Frog[n];
for (int i = 0; i < n; i++) {
frogs[i] = new Frog(Long.parseLong(second[i]), Long.parseLong(third[i]));
}
int left = k;
int right = k;
long min = frogs[k].position - frogs[k].strength;
long max = frogs[k].position + frogs[k].strength;
boolean flag = true;
while (flag) {
flag = false;
while (left > 0 && frogs[left - 1].position >= min) {
min = Math.min(min, frogs[left - 1].position - frogs[left - 1].strength);
left--;
flag = true;
}
while (right < n - 1 && frogs[right + 1].position <= max) {
max = Math.max(max, frogs[right + 1].position + frogs[right + 1].strength);
right++;
flag = true;
}
}
System.out.println(right - left + 1);
}
static class Frog {
long position;
long strength;
public Frog(long position, long strength) {
this.position = position;
this.strength = strength;
}
}
}
tenten