結果
問題 |
No.1409 Simple Math in yukicoder
|
ユーザー |
![]() |
提出日時 | 2021-02-27 07:07:03 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 178 ms / 2,000 ms |
コード長 | 750 bytes |
コンパイル時間 | 343 ms |
コンパイル使用メモリ | 82,912 KB |
実行使用メモリ | 77,440 KB |
最終ジャッジ日時 | 2024-10-02 17:01:35 |
合計ジャッジ時間 | 32,839 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 58 |
ソースコード
def prime_factors(N): #素因数のリスト factors = [] if N&1==0: factors = [2] while N%2 == 0: N //= 2 else: factorization = [] M = int(N**0.5)+1 for i in range(3,M,2): if N%i==0: while N%i == 0: N //= i factors.append(i) if N!= 1: factors.append(N) assert N != 0, "zero" return factors def solve(v,x): p = v*x+1 ps = prime_factors(v)+prime_factors(x) r = 1 for r in range(2,p): for pp in ps: if pow(r,v*x//pp,p) == 1: break else: break a = [pow(r,i*v,p) for i in range(x)] return sorted(a) T = int(input()) for _ in range(T): v,x = map(int,input().split()) print(*solve(v,x))