結果
| 問題 |
No.1666 累乗数
|
| コンテスト | |
| ユーザー |
とりゐ
|
| 提出日時 | 2022-12-21 02:11:00 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 549 ms / 2,000 ms |
| コード長 | 926 bytes |
| コンパイル時間 | 435 ms |
| コンパイル使用メモリ | 82,392 KB |
| 実行使用メモリ | 76,848 KB |
| 最終ジャッジ日時 | 2024-11-18 02:29:43 |
| 合計ジャッジ時間 | 6,494 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 19 |
ソースコード
from sys import stdin
input=lambda :stdin.readline()[:-1]
def kth_root_int(a, k):
assert 0 <= a and 0 < k
if a == 0:
return 0
if k == 1:
return a
ret = int(pow(a, 1 / k))
while pow(ret + 1, k) <= a:
ret += 1
while pow(ret, k) > a:
ret -= 1
return ret
check=[(2, -1), (3, -1), (5, -1), (6, 1), (7, -1), (10, 1), (11, -1), (13, -1), (14, 1), (15, 1), (17, -1), (19, -1), (21, 1), (22, 1), (23, -1), (26, 1), (29, -1), (30, -1), (31, -1), (33, 1), (34, 1), (35, 1), (37, -1), (38, 1), (39, 1), (41, -1), (42, -1), (43, -1), (46, 1), (47, -1), (51, 1), (53, -1), (55, 1), (57, 1), (58, 1), (59, -1)]
def count(n):
res=-1
for k,sgn in check:
res-=sgn*kth_root_int(n,k)
return res
t=int(input())
for _ in range(t):
k=int(input())
ng,ok=0,k**2+1
while abs(ok-ng)>1:
mid=(ok+ng)//2
if count(mid)>=k:
ok=mid
else:
ng=mid
print(ok)
とりゐ