結果

問題 No.889 素数!
ユーザー lloyz
提出日時 2022-04-06 01:24:50
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 28 ms / 2,000 ms
コード長 601 bytes
コンパイル時間 77 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 10,752 KB
最終ジャッジ日時 2024-11-27 11:10:58
合計ジャッジ時間 3,589 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 61
権限があれば一括ダウンロードができます

ソースコード

diff #

IsPrime = [True for _ in range(64)]
IsPrime[0] = IsPrime[1] = False
for i in range(2, 64):
    if IsPrime[i]:
        for j in range(i + i, 64, i):
            IsPrime[j] = False

n = int(input())
if IsPrime[n]:
    print("Sosu!")
elif n in [4, 9, 16, 25, 36, 49]:
    print("Heihosu!")
elif n in [8, 27]:
    print("Ripposu!")
elif n in [0, 1]:
    print(n)
else:
    f = 2
    temp = 1
    while f * f <= n:
        if n % f == 0:
            temp += f
            if n // f != f:
                temp += n // f
        f += 1
    if temp == n:
        print("Kanzensu!")
    else:
        print(n)
0