結果
問題 | No.173 カードゲーム(Medium) |
ユーザー | nebukuro09 |
提出日時 | 2016-11-10 13:03:30 |
言語 | D (dmd 2.109.1) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,034 bytes |
コンパイル時間 | 1,389 ms |
コンパイル使用メモリ | 142,172 KB |
最終ジャッジ日時 | 2024-11-14 19:53:57 |
合計ジャッジ時間 | 1,776 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
Main.d(44): Error: function `Main.simulate(int[] A, int[] B)` is not callable using argument types `(SortedRange!(int[], "a < b", SortedRangeOptions.assumeSorted), SortedRange!(int[], "a < b", SortedRangeOptions.assumeSorted))` Main.d(44): cannot pass argument `A` of type `SortedRange!(int[], "a < b", SortedRangeOptions.assumeSorted)` to parameter `int[] A`
ソースコード
import std.stdio; import std.array; import std.string; import std.conv; import std.algorithm; import std.typecons; import std.range; import std.random; import std.math; import std.container; int N; int Pa, Pb; bool simulate(int[] A, int[] B){ int Sa, Sb; foreach (i; 0..N-1) { int a = Pa > uniform(0, 1000) ? 0 : uniform(1, N-i); int b = Pb > uniform(0, 1000) ? 0 : uniform(1, N-i); if (A[a] > B[b]) Sa += A[a]+B[b]; else if (B[b] > A[a]) Sb += A[a]+B[b]; A = A[0..a] ~ A[a+1..$]; B = B[0..b] ~ B[b+1..$]; } if (A[0] > B[0]) Sa += A[0]+B[0]; else if (B[0] > A[0]) Sb += A[0]+B[0]; return Sa > Sb; } void main() { auto input = readln.split; N = input[0].to!int; Pa = (input[1]~"000")[2..5].to!int; Pb = (input[2]~"000")[2..5].to!int; auto A = readln.split.map!(to!int).array.sort; auto B = readln.split.map!(to!int).array.sort; int ans = 0; int times = 20000; foreach (i; 0..times) if (simulate(A, B)) ans += 1; writeln(ans.to!double / times); }