提出 #72254159


ソースコード 拡げる

"""
<方針>
- `while` 文でループ処理する。
- `1` になったら `Yes` を出力してプログラムを終了する。
- 生成された数字もメモしておき、すでに存在した数字で無限ループ入りそうになってもループを抜ける。
"""
# 入力
N = int(input())

# 生成された数字集合
se = set()

# ループ処理
while (N not in se):
  # ハッピー!
  if(N == 1):
    print("Yes")
    exit()
  
  # 集合に登録
  se.add(N)
  
  # 次の数字を計算
  N = sum([int(n)**2 for n in str(N)])
print("No")

提出情報

提出日時
問題 B - Happy Number
ユーザ mattsunkun
言語 Python (PyPy 3.11-v7.3.20)
得点 200
コード長 587 Byte
結果 AC
実行時間 50 ms
メモリ 80004 KiB

ジャッジ結果

セット名 Sample All after_contest
得点 / 配点 0 / 0 200 / 200 0 / 0
結果
AC × 3
AC × 23
AC × 2
セット名 テストケース
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt
after_contest after_contest_01.txt, after_contest_02.txt
ケース名 結果 実行時間 メモリ
after_contest_01.txt AC 50 ms 79860 KiB
after_contest_02.txt AC 50 ms 79676 KiB
sample_01.txt AC 50 ms 79904 KiB
sample_02.txt AC 50 ms 80004 KiB
sample_03.txt AC 50 ms 79804 KiB
test_01.txt AC 49 ms 79736 KiB
test_02.txt AC 50 ms 79908 KiB
test_03.txt AC 50 ms 79668 KiB
test_04.txt AC 50 ms 79716 KiB
test_05.txt AC 50 ms 79904 KiB
test_06.txt AC 50 ms 79532 KiB
test_07.txt AC 49 ms 79812 KiB
test_08.txt AC 49 ms 79716 KiB
test_09.txt AC 49 ms 79732 KiB
test_10.txt AC 49 ms 80004 KiB
test_11.txt AC 50 ms 79632 KiB
test_12.txt AC 50 ms 79672 KiB
test_13.txt AC 50 ms 79696 KiB
test_14.txt AC 49 ms 79636 KiB
test_15.txt AC 50 ms 79732 KiB
test_16.txt AC 50 ms 79816 KiB
test_17.txt AC 49 ms 79844 KiB
test_18.txt AC 49 ms 79588 KiB
test_19.txt AC 50 ms 79668 KiB
test_20.txt AC 50 ms 79808 KiB