結果
| 問題 | 
                            No.9 モンスターのレベル上げ
                             | 
                    
| コンテスト | |
| ユーザー | 
                             Sounds_Of_Rain
                         | 
                    
| 提出日時 | 2015-07-20 12:10:58 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                WA
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 977 bytes | 
| コンパイル時間 | 698 ms | 
| コンパイル使用メモリ | 86,648 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-07-08 11:12:23 | 
| 合計ジャッジ時間 | 3,580 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 15 WA * 5 | 
ソースコード
#define _CRT_SECURE_NO_WARNINGS
#include <cstdio>
#include <cstring>
#include <cmath>
#include <vector>
#include <list>
#include <string>
#include <set>
#include <map>
#include <queue>
#include <stack>
#include <algorithm>
#include <iostream>
#include <sstream>
using namespace std;
typedef long long int llint;
const int INF = 1000000;
const llint LINF = 100000000;
int main(){
	int A[1500];
	int B[1500];
	int n,ans = INF;
	priority_queue<pair<int, int>>st;
	cin >> n;
	for (int i = 0; i < n; i++){
		cin >> A[i];
		st.push(make_pair(-A[i],0));
	}
	for (int i = 0; i < n; i++){
		cin >> B[i];
	}
	for (int i = 0; i < n; i++){
		int cc = 0;
		priority_queue<pair<int, int>>pq = st;
		for (int j = i; j < n+i; j++){
			
			pair<int, int> P = pq.top();
			pq.pop();
			P.second++;
			if (j < n){
				P.first -= B[j] / 2;
			}
			else{
				P.first -= B[j - n] / 2;
			}
				pq.push(P);
				cc = max(cc, P.second);
		}
		ans = min(cc, ans);
	}
	cout << ans << endl;
	return 0;
}
            
            
            
        
            
Sounds_Of_Rain