結果
問題 | No.98 円を描こう |
ユーザー |
|
提出日時 | 2016-08-27 17:46:10 |
言語 | D (dmd 2.109.1) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 544 bytes |
コンパイル時間 | 829 ms |
コンパイル使用メモリ | 102,144 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-12 03:45:15 |
合計ジャッジ時間 | 1,162 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 6 |
ソースコード
import std.algorithm, std.array, std.range;import std.string, std.conv;import std.math;import std.stdio, std.typecons;void main(){auto rd = readln.split.map!(to!int);auto xp = rd[0];auto yp = rd[1];auto max = (sqrt((10000 ^^ 2 * 2).to!real) * 2).to!int + 1;writeln(calc(xp, yp, max));}int calc(int xp, int yp, int max){auto d1 = 4 * (xp ^^ 2 + yp ^^ 2);auto r = 1;for (; r <= max; ++r) {auto d2 = r ^^ 2;if (d1 == d2)return r + 1;else if (d1 < d2)return r;}return max;}