結果
問題 | No.133 カードゲーム |
ユーザー | hiroa |
提出日時 | 2019-12-07 11:35:04 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 5,000 ms |
コード長 | 710 bytes |
コンパイル時間 | 1,657 ms |
コンパイル使用メモリ | 169,528 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-12-24 21:05:14 |
合計ジャッジ時間 | 2,567 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 19 |
ソースコード
#include<bits/stdc++.h> using namespace std; typedef long long ll; #define MOD 1000000007 #define INF 1e9 #define rep(i,n) for (int i = 0; i < (n); ++i) #define all(x) (x).begin(),(x).end() template<typename T> using min_priority_queue = priority_queue<T, vector<T>, greater<T>>; int main(){ int N; cin>>N; vector<int> A(N); vector<int> B(N); rep(i,N) cin>>A[i]; rep(i,N) cin>>B[i]; vector<int> NA(N),NB(N); rep(i,N) NA[i]=NB[i]=i; int ok=0,count=0; do{ do{ int win=0; rep(i,N){ if(A[NA[i]]>B[NB[i]]) win++; else win--; } if(win>0) ok++; count++; }while(next_permutation(all(NA))); }while(next_permutation(all(NB))); cout<<setprecision(10)<<(double)ok/count<<endl; }