結果
| 問題 | No.377 背景パターン |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-06-05 16:57:19 |
| 言語 | Ruby (4.0.0) |
| 結果 |
RE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 423 bytes |
| 記録 | |
| コンパイル時間 | 271 ms |
| コンパイル使用メモリ | 7,680 KB |
| 実行使用メモリ | 12,928 KB |
| 最終ジャッジ日時 | 2024-10-08 15:58:55 |
| 合計ジャッジ時間 | 3,005 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | RE * 5 |
| other | RE * 14 |
コンパイルメッセージ
Main.rb:3: warning: `?' just followed by `yield' is interpreted as a conditional operator, put a space after `?' Syntax OK
ソースコード
require 'prime'
def x(a,d,n,t)
d==a.size ?yield(n,t):(0..a[d][1]).map{|i|x(a,d+1,n*a[d][0]**i,i==0 ? t : t*(a[d][0]-1)*a[d][0]**(i-1),&proc)}
end
def q(x,y)
z=1
(y%2>0&&z=z*x%M;x=x*x%M;y/=2)while y>0
z
end
C={}
M=1000000007
H,W,K=gets.split.map &:to_i
B=W.prime_division
x(H.prime_division,r=0,1,1){|a,at|
x(B,0,1,1){|b,bt|
k=W*H*a.gcd(b)/a/b
C[k]=q(K,k) if !C.has_key?k
r=(r+at*bt*C[k])%M
}
}
p r*q(W*H,M-2)%M