結果
| 問題 | No.3520 L1等距離点 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2026-05-01 21:27:29 |
| 言語 | C# (.NET 10.0.201) |
| 結果 |
AC
|
| 実行時間 | 84 ms / 2,000 ms |
| コード長 | 750 bytes |
| 記録 | |
| コンパイル時間 | 8,503 ms |
| コンパイル使用メモリ | 174,864 KB |
| 実行使用メモリ | 51,488 KB |
| 平均クエリ数 | 6.94 |
| 最終ジャッジ日時 | 2026-05-01 21:27:47 |
| 合計ジャッジ時間 | 13,927 ms |
|
ジャッジサーバーID (参考情報) |
judge2_1 / judge3_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 35 |
コンパイルメッセージ
復元対象のプロジェクトを決定しています... /home/judge/data/code/main.csproj を復元しました (83 ミリ秒)。 main -> /home/judge/data/code/bin/Release/net10.0/main.dll main -> /home/judge/data/code/bin/Release/net10.0/publish/
ソースコード
#nullable enable
#region
var (_input, _iter) = (Array.Empty<string>(), 0);
T I<T>() where T : IParsable<T>
{
while (_iter >= _input.Length) (_input, _iter) = (Console.ReadLine()!.Trim().Split(' '), 0);
return T.Parse(_input[_iter++], null);
}
#endregion
var t = I<int>();
var x0 = I<int>();
var y0 = I<int>();
var xt = I<int>();
var yt = I<int>();
int D(int x0, int y0, int x1, int y1) => Math.Abs(x0 - x1) + Math.Abs(y0 - y1);
var pass = 0;
var fail = t;
while (Math.Abs(pass - fail) >= 2)
{
var mid = (pass + fail) >> 1;
Console.WriteLine("? " + mid);
var xm = I<int>();
var ym = I<int>();
var f = D(x0, y0, xm, ym) <= D(xt, yt, xm, ym);
if (f) pass = mid;
else fail = mid;
}
Console.WriteLine("! " + pass);