結果
| 問題 | No.904 サメトロ | 
| コンテスト | |
| ユーザー |  沙耶花 | 
| 提出日時 | 2019-10-11 21:52:37 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 17 ms / 1,000 ms | 
| コード長 | 783 bytes | 
| コンパイル時間 | 1,570 ms | 
| コンパイル使用メモリ | 168,344 KB | 
| 実行使用メモリ | 6,820 KB | 
| 最終ジャッジ日時 | 2024-11-25 07:16:21 | 
| 合計ジャッジ時間 | 2,651 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 33 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
#define modulo 998244353
#define mod(mod_x) ((((long long)mod_x+modulo))%modulo)
#define Inf 1000000000000000000
int main(){
	
	int N;
	cin>>N;
	
	
	int sumA=0,sumB=0;
	vector<int> A(N-1),B(N-1);
	for(int i=0;i<N-1;i++){
		cin>>A[i]>>B[i];
		sumA += A[i];
		sumB += B[i];
	}
	
	
	int AA,BB;
	if(sumA>sumB){
		AA=0;
		BB=sumA-sumB;
		sumB+=BB;
	}
	else{
		AA=sumB-sumA;
		BB=0;
		sumA+=AA;
	}
	
	int ans = 0;
	
	while(true){
		bool f = true;
		for(int i=0;i<N-1;i++){
			if(A[i]>sumB-B[i]||B[i]>sumA-A[i]){
				AA++;
				BB++;
				sumA++;
				sumB++;
				f=false;
				break;
			}
		}
		if(!f)continue;
		if(AA>sumB-BB||BB>sumA-AA){
			break;
		}
		ans++;
		AA++;
		BB++;
		sumA++;
		sumB++;
	}
	cout<<ans<<endl;
		
	
    return 0;
}
            
            
            
        