結果
| 問題 |
No.2271 平方根の13桁精度近似計算
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-04-14 22:57:18 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 49 ms / 2,000 ms |
| コード長 | 457 bytes |
| コンパイル時間 | 145 ms |
| コンパイル使用メモリ | 82,408 KB |
| 実行使用メモリ | 63,616 KB |
| 最終ジャッジ日時 | 2024-10-10 13:57:47 |
| 合計ジャッジ時間 | 3,057 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 40 |
ソースコード
import sys
N = int(input())
E = int(input())
offset = 1 << 29
if N >= 0 and round(N ** 0.5) ** 2 == N:
print(round(N ** 0.5))
sys.exit()
cand = set([0])
key = 1
for i in range(E):
n_cand = set()
for i in range(5):
for j in cand:
if ((j + i * key) ** 2 - N) % (key * 5) == 0:
n_cand.add(j + i * key)
cand = n_cand
key *= 5
for i in cand:
if (i + offset) % key - offset <= offset:
print((i + offset) % key - offset)
sys.exit()
print("NaN")