結果
| 問題 | No.1279 Array Battle | 
| コンテスト | |
| ユーザー | 👑 | 
| 提出日時 | 2021-11-25 00:25:34 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 8 ms / 2,000 ms | 
| コード長 | 839 bytes | 
| コンパイル時間 | 678 ms | 
| コンパイル使用メモリ | 75,584 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-06-27 10:05:52 | 
| 合計ジャッジ時間 | 1,468 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 20 | 
ソースコード
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main(){
    int n;cin>>n;
    vector<int> A(n),B(n);
    for(int i = 0; n > i; i++){
        cin>>A[i];
    }
    for(int i = 0; n > i; i++){
        cin>>B[i];
    }
    sort(A.begin(),A.end());
    int nw = 1;
    int plu = 1;
    for(int i = 1; n > i; i++){
      if(A[i-1] == A[i]){
        nw++;
        plu *= nw;
      }else{
        nw = 1;
      }
    }
    int ans = 0;
    int t = 0;
    do{
        int tmp = 0;
        for(int i = 0; n > i; i++){
            if(A[i] > B[i]){
                tmp += A[i]-B[i];
            }
        }
        if(tmp > ans){
            ans = tmp;
            t = 1;
        }else if(tmp == ans){
            t++;
        }
        
    }while(next_permutation(A.begin(),A.end()));
    cout << t*plu << endl;
}
            
            
            
        