結果
| 問題 |
No.514 宝探し3
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-12-24 01:34:12 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 20 ms / 2,000 ms |
| コード長 | 1,365 bytes |
| コンパイル時間 | 11,148 ms |
| コンパイル使用メモリ | 380,200 KB |
| 実行使用メモリ | 25,476 KB |
| 平均クエリ数 | 4.08 |
| 最終ジャッジ日時 | 2024-11-18 05:04:41 |
| 合計ジャッジ時間 | 12,676 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 12 |
ソースコード
fn main() {
let lowerx = 0isize;
let upperx = 1e9 as isize;
let tempy = 0isize;
let lowery = 0isize;
let uppery = 1e9 as isize;
println!("{} {}", lowerx, tempy);
let mut dist0 = String::new();
std::io::stdin().read_line(&mut dist0).ok();
let dist0: isize = dist0.trim().parse().unwrap();
if dist0 == 0 {
return;
}
println!("{} {}", upperx, tempy);
let mut dist1 = String::new();
std::io::stdin().read_line(&mut dist1).ok();
let dist1: isize = dist1.trim().parse().unwrap();
if dist1 == 0 {
return;
}
let diffx = dist0.max(dist1) - dist0.min(dist1);
let diffx = diffx / 2;
let x = (lowerx + upperx) / 2 + if dist0 > dist1 { diffx } else { -diffx };
println!("{} {}", x, lowery);
let mut dist0 = String::new();
std::io::stdin().read_line(&mut dist0).ok();
let dist0: isize = dist0.trim().parse().unwrap();
if dist0 == 0 {
return;
}
println!("{} {}", x, uppery);
let mut dist1 = String::new();
std::io::stdin().read_line(&mut dist1).ok();
let dist1: isize = dist1.trim().parse().unwrap();
if dist1 == 0 {
return;
}
let diffy = dist0.max(dist1) - dist0.min(dist1);
let diffy = diffy / 2;
let y = (lowery + uppery) / 2 + if dist0 > dist1 { diffy } else { -diffy };
println!("{} {}", x, y);
}