結果
| 問題 |
No.181 A↑↑N mod M
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-04-06 12:08:51 |
| 言語 | Ruby (3.4.1) |
| 結果 |
WA
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 651 bytes |
| コンパイル時間 | 163 ms |
| コンパイル使用メモリ | 7,552 KB |
| 実行使用メモリ | 12,544 KB |
| 最終ジャッジ日時 | 2024-07-04 03:23:32 |
| 合計ジャッジ時間 | 5,572 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 6 |
| other | AC * 34 WA * 3 |
コンパイルメッセージ
Syntax OK
ソースコード
require 'prime'
def phi(n)
ps = Array.new
Prime.each(n) do |p|
ps.push(p) if n % p == 0
end
ret = n
ps.each do |p|
ret *= (1.0 - (1.0/p))
end
return ret.round
end
def modpow(b,e,m)
res = 1
while e > 0
if e & 1 == 1
res = (res * b) % m
end
e >>= 1
b = (b * b) % m
end
res
end
def rec(a,n,m)
return 1 if n == 0
return 0 if m == 1
m2 = phi(m)
b = rec(a,n-1,m2) + m2
return modpow(a,b,m)
end
a, n, m = gets.split.map(&:to_i)
if n == 0
p 1 % m
elsif n == 1
p a % m
elsif n == 2
p modpow(a,a,m)
else
p rec(a,n,m)
end