結果
| 問題 | No.133 カードゲーム |
| コンテスト | |
| ユーザー |
rsk0315
|
| 提出日時 | 2019-02-11 23:55:23 |
| 言語 | C++17 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 745 ms / 5,000 ms |
| コード長 | 638 bytes |
| 記録 | |
| コンパイル時間 | 562 ms |
| コンパイル使用メモリ | 108,412 KB |
| 実行使用メモリ | 6,400 KB |
| 最終ジャッジ日時 | 2026-06-07 06:49:33 |
| 合計ジャッジ時間 | 12,914 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge2_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 19 |
ソースコード
#include <cstdio>
#include <vector>
#include <algorithm>
#include <random>
std::mt19937 rsk(0315);
bool wins(std::vector<int>& A, std::vector<int> &B) {
std::shuffle(A.begin(), A.end(), rsk);
std::shuffle(B.begin(), B.end(), rsk);
size_t N = A.size();
int a = 0;
int b = 0;
for (size_t i = 0; i < N; ++i)
++((A[i] > B[i])? a:b);
return a > b;
}
int main() {
size_t N;
scanf("%zu", &N);
std::vector<int> A(N), B(N);
for (auto& ai: A) scanf("%d", &ai);
for (auto& bi: B) scanf("%d", &bi);
int win = 0;
for (int i = 0; i < 10000000; ++i)
if (wins(A, B))
++win;
printf("%.6f\n", win*1e-7);
}
rsk0315