結果

問題 No.187 中華風 (Hard)
ユーザー cielciel
提出日時 2015-04-20 15:14:20
言語 Ruby
(3.3.0)
結果
AC  
実行時間 821 ms / 3,000 ms
コード長 356 bytes
コンパイル時間 215 ms
コンパイル使用メモリ 7,680 KB
実行使用メモリ 21,248 KB
最終ジャッジ日時 2024-07-04 17:57:44
合計ジャッジ時間 10,956 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 84 ms
12,032 KB
testcase_01 AC 77 ms
12,032 KB
testcase_02 AC 104 ms
16,896 KB
testcase_03 AC 105 ms
16,896 KB
testcase_04 AC 759 ms
20,992 KB
testcase_05 AC 740 ms
20,992 KB
testcase_06 AC 746 ms
20,736 KB
testcase_07 AC 757 ms
20,608 KB
testcase_08 AC 813 ms
21,248 KB
testcase_09 AC 800 ms
21,248 KB
testcase_10 AC 821 ms
20,992 KB
testcase_11 AC 758 ms
20,608 KB
testcase_12 AC 768 ms
20,480 KB
testcase_13 AC 85 ms
12,160 KB
testcase_14 AC 84 ms
12,160 KB
testcase_15 AC 102 ms
15,744 KB
testcase_16 AC 106 ms
15,872 KB
testcase_17 AC 81 ms
12,032 KB
testcase_18 AC 82 ms
11,904 KB
testcase_19 AC 78 ms
11,904 KB
testcase_20 AC 531 ms
19,712 KB
testcase_21 AC 75 ms
12,032 KB
testcase_22 AC 731 ms
20,352 KB
testcase_23 AC 75 ms
12,160 KB
testcase_24 AC 75 ms
11,904 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.rb:10: warning: assigned but unused variable - y
Syntax OK

ソースコード

diff #

#!/usr/bin/ruby
def egcd(x,y)
	return[x,1,0]if y==0
	g,a,b=egcd(y,x%y)
	[g,b,a-x/y*b]
end
def chinese(a)
	return nil if !a||a.empty?
	a.reduce([0,1]){|(a1,m1),(a2,m2)|
		g,x,y=egcd(m1,m2)
		v=(a2-a1)/g
		break if v*g!=a2-a1
		lcm=m1/g*m2
		[(a1+v*x*m1)%lcm,lcm]
	}
end
r=chinese($<.drop(1).map{|e|e.split.map &:to_i})
p r ?(r[0]==0?r[1]:r[0])%1000000007:-1
0