結果
| 問題 | 
                            No.377 背景パターン
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2016-06-05 16:55:38 | 
| 言語 | Ruby  (3.4.1)  | 
                    
| 結果 | 
                             
                                RE
                                 
                             
                            
                            (最新)
                                AC
                                 
                             
                            (最初)
                            
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 450 bytes | 
| コンパイル時間 | 232 ms | 
| コンパイル使用メモリ | 7,424 KB | 
| 実行使用メモリ | 12,928 KB | 
| 最終ジャッジ日時 | 2024-10-08 15:58:47 | 
| 合計ジャッジ時間 | 2,958 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge2 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | RE * 5 | 
| other | RE * 14 | 
コンパイルメッセージ
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 pow(x,y,m)
	z=1
	while y>0
		z=z*x%m if y%2>0
		x=x*x%m
		y/=2
	end
	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]=pow(K,k,M) if !C.has_key?k
		r=(r+at*bt*C[k])%M
	}
}
p r*pow(W*H,M-2,M)%M