結果
| 問題 | 
                            No.377 背景パターン
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2016-06-05 16:57:19 | 
| 言語 | Ruby  (3.4.1)  | 
                    
| 結果 | 
                             
                                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