結果
問題 | No.1529 Constant Lcm |
ユーザー | 👑 SPD_9X2 |
提出日時 | 2021-06-04 20:26:56 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 259 ms / 3,000 ms |
コード長 | 1,083 bytes |
コンパイル時間 | 192 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 96,000 KB |
最終ジャッジ日時 | 2024-11-19 09:02:06 |
合計ジャッジ時間 | 4,452 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 24 |
ソースコード
""" 後半はいらない 素数のmaxをとる 全ての約数素数に関してやる? logにはなるかな… """ import sys from sys import stdin N = int(stdin.readline()) def Sieve(n): #n以下の素数全列挙(O(nloglogn)) retは素数が入ってる。divlisはその数字の素因数が一つ入ってる ret = [] divlis = [-1] * (n+1) #何で割ったかのリスト(初期値は-1) flag = [True] * (n+1) flag[0] = False flag[1] = False ind = 2 while ind <= n: if flag[ind]: ret.append(ind) ind2 = ind ** 2 while ind2 <= n: flag[ind2] = False divlis[ind2] = ind ind2 += ind ind += 1 return ret,divlis plis,divlis= Sieve(N+10) ans = 1 mod = 998244353 #print (plis) for p in plis: nmax = 0 for i in range(p,N,p): rev = (N-i) * i now = 0 while rev % p == 0: rev //= p now += 1 nmax = max(now,nmax) ans *= pow(p,nmax,mod) ans %= mod print (ans)