結果
| 問題 | No.2918 Divide Applicants Fairly | 
| ユーザー |  | 
| 提出日時 | 2024-10-08 22:26:41 | 
| 言語 | C++23 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                TLE
                                 
                             | 
| 実行時間 | - | 
| コード長 | 716 bytes | 
| コンパイル時間 | 3,220 ms | 
| コンパイル使用メモリ | 258,364 KB | 
| 実行使用メモリ | 249,344 KB | 
| 最終ジャッジ日時 | 2024-10-08 22:28:04 | 
| 合計ジャッジ時間 | 64,725 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 55 TLE * 6 | 
ソースコード
#include<bits/stdc++.h>
using namespace std;
#pragma GCC target("avx2")
#pragma GCC optimize("O3")
#pragma GCC optimize("unroll-loops")
int main(){
	int n;
	cin >> n;
	vector<int> a(n);
	for(int i=0; i<n; i++) cin >> a[i];
	const int sz = 24000005;
	vector<bitset<sz>> dp(n+1);
	for(int i=0; i<n; i++){
		auto ndp = dp;
		for(int j=max(0, n/2-i); j<=min(n/2+i, n); j++){
			if(j != 0) ndp[j-1] |= dp[j]>>a[i];
			if(j != n) ndp[j+1] |= dp[j]<<a[i];
		}
		swap(ndp, dp);
		if(dp[n/2].test(sz/3)){
			cout << 0 << endl;
			return 0;
		}
		dp[n/2+1].set(sz/3+a[i], 1);
	}
	int ans = 1e9;
	for(int i=sz/3-800000; i<=sz/3+800000; i++){
		if(dp[n/2].test(i)) ans = min(ans, max(sz/3-i, i-sz/3));
	}
	cout << ans << endl;
}
            
            
            
        