結果
問題 | No.2426 Select Plus or Minus |
ユーザー |
![]() |
提出日時 | 2023-08-18 21:17:59 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 40 ms / 2,000 ms |
コード長 | 587 bytes |
コンパイル時間 | 334 ms |
コンパイル使用メモリ | 82,280 KB |
実行使用メモリ | 52,608 KB |
最終ジャッジ日時 | 2024-11-28 05:21:59 |
合計ジャッジ時間 | 4,076 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 41 |
ソースコード
N = int(input()) ND = N MAXND = N ANS = [] while ND>1: if ND%2==0: ND=ND//2 ANS.append('/') elif ND>120: ND=ND*3-1 ANS.append('-') else: ND=ND*3+1 ANS.append('+') MAXND = max(MAXND,ND) if MAXND<=10**18 and len(ANS)<=10000: print(len(ANS)) print(''.join(ANS)) exit() ANS = [] S = set() while N>1: if N%2==0: N=N//2 ANS.append('/') elif not N in S: N=N*3-1 ANS.append('-') else: N=N*3+1 ANS.append('+') S.add(N) print(len(ANS)) print(''.join(ANS))