結果

問題 No.1279 Array Battle
ユーザー ぷらぷら
提出日時 2021-03-13 01:07:59
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 12 ms / 2,000 ms
コード長 814 bytes
コンパイル時間 1,607 ms
コンパイル使用メモリ 170,264 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-14 14:59:52
合計ジャッジ時間 2,108 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int main() {
    int N;
    cin >> N;
    vector<int>tmp(N);
    iota(tmp.begin(),tmp.end(),0);
    vector<int>a(N),b(N);
    for(int i = 0; i < N; i++) {
        cin >> a[i];
    }
    for(int i = 0; i < N; i++) {
        cin >> b[i];
    }
    int ans = 0;
    do {
        int cnt = 0;
        for(int i = 0; i < N; i++) {
            cnt += max(0,a[tmp[i]]-b[i]);
        }
        ans = max(ans,cnt);
    }while(next_permutation(tmp.begin(),tmp.end()));
    int fans = 0;
    iota(tmp.begin(),tmp.end(),0);
    do {
        int cnt = 0;
        for(int i = 0; i < N; i++) {
            cnt += max(0,a[tmp[i]]-b[i]);
        }
        if(cnt == ans) {
            fans++;
        }
    }while(next_permutation(tmp.begin(),tmp.end()));
    cout << fans << endl;
}
0