結果
| 問題 |
No.871 かえるのうた
|
| コンテスト | |
| ユーザー |
tenten
|
| 提出日時 | 2021-03-16 10:41:50 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 408 ms / 2,000 ms |
| コード長 | 1,597 bytes |
| コンパイル時間 | 1,924 ms |
| コンパイル使用メモリ | 77,436 KB |
| 実行使用メモリ | 65,800 KB |
| 最終ジャッジ日時 | 2024-11-30 11:06:08 |
| 合計ジャッジ時間 | 11,143 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 49 |
ソースコード
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);
max = Math.max(max, frogs[left - 1].position + frogs[left - 1].strength);
left--;
flag = true;
}
while (right < n - 1 && frogs[right + 1].position <= max) {
min = Math.min(min, frogs[right + 1].position - frogs[right + 1].strength);
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