結果
問題 | No.1259 スイッチ |
ユーザー |
👑 ![]() |
提出日時 | 2020-10-16 22:26:06 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 59 ms / 2,000 ms |
コード長 | 763 bytes |
コンパイル時間 | 263 ms |
コンパイル使用メモリ | 82,344 KB |
実行使用メモリ | 58,240 KB |
最終ジャッジ日時 | 2024-07-20 22:30:22 |
合計ジャッジ時間 | 4,870 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 61 |
ソースコード
"""https://yukicoder.me/problems/no/1259M=1以外はすべて同じと扱えるK回後に1にいる場合だけを計算すればよい1ループがKの約数ならおkKの約数でN以下のやつを見つける"""def inverse(a,mod): #aのmodを法にした逆元を返すreturn pow(a,mod-2,mod)N,K,M = map(int,input().split())mans = 0nfac = 1mod = 10**9+7npow = pow(N,N-1,mod)inv = inverse(N,mod)for i in range(1,N+1):#i回移動で戻る場合を計算するif K % i == 0:mans += npow * nfacmans %= mod#print (i,nfac,npow)nfac = nfac * (N-i) % modnpow = npow * inv % modif M == 1:print (mans)else:ans = (pow(N,N,mod) - mans) * inverse(N-1,mod) % modprint (ans)