結果
問題 | No.1287 えぬけー |
ユーザー | persimmon-persimmon |
提出日時 | 2021-02-16 21:20:48 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,774 ms / 2,000 ms |
コード長 | 784 bytes |
コンパイル時間 | 1,339 ms |
コンパイル使用メモリ | 81,756 KB |
実行使用メモリ | 386,080 KB |
最終ジャッジ日時 | 2024-09-13 10:45:11 |
合計ジャッジ時間 | 8,336 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 39 ms
52,212 KB |
testcase_01 | AC | 39 ms
52,224 KB |
testcase_02 | AC | 39 ms
52,980 KB |
testcase_03 | AC | 39 ms
52,880 KB |
testcase_04 | AC | 39 ms
52,628 KB |
testcase_05 | AC | 1,706 ms
373,144 KB |
testcase_06 | AC | 1,711 ms
373,728 KB |
testcase_07 | AC | 1,774 ms
386,080 KB |
testcase_08 | AC | 1,662 ms
373,408 KB |
ソースコード
import sys sys.setrecursionlimit(10**7) t=int(input()) cases=[list(map(int,input().split())) for _ in range(t)] mod=10**9+7 memo={} def ext_gcd(a, b): # a*x+b*y==gcd(a,b)たるgcd(a,b),x,y if (a,b) in memo:return memo[(a,b)] if b > 0: d,x,y = ext_gcd(b,a % b) memo[(a,b)]=d,y,x-(a//b)*y return d,y,x-(a//b)*y return a,1,0 for x,k in cases: # x=n^k (mod)となるnを求める。k:奇数 <=5*10**8 # x^i=n^(i*k) (mod) # ここでi*k%(mod-1)=1なら、フェルマーの小定理より # x^i=n (mod) # となる。 # i*k%(mod-1)=1となるiを探す。 # kの制約よりkとmod-1は互いに素 # ある(i,j)があり、i*k=j*(mod-1)+1 # i*k+j*(mod-1)=1 g,i,j=ext_gcd(k,mod-1) if i<0: x=pow(x,mod-2,mod) i=abs(i) print(pow(x,i,mod))