結果
| 問題 | No.4 おもりと天秤 | 
| コンテスト | |
| ユーザー |  muripoyotaro | 
| 提出日時 | 2018-08-15 11:29:18 | 
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 18 ms / 5,000 ms | 
| コード長 | 639 bytes | 
| コンパイル時間 | 593 ms | 
| コンパイル使用メモリ | 72,472 KB | 
| 最終ジャッジ日時 | 2025-01-06 12:20:07 | 
| ジャッジサーバーID (参考情報) | judge1 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 23 | 
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:30:18: warning: ‘x’ may be used uninitialized [-Wmaybe-uninitialized]
   30 |         if(sum==2*x){
      |                 ~^~
main.cpp:25:12: note: ‘x’ was declared here
   25 |         ll x;
      |            ^
            
            ソースコード
#include<iostream>
#include<vector>
typedef long long ll;
using namespace std;
int main() {
	ll N;
	cin >> N;
	vector<ll>a(N);
  	ll sum=0;
	for (ll i = 0; i < N; i++) {
		cin >> a[i];
      	sum+=a[i];
	}
	ll dp[10001];
	for (ll i = 0; i <=10000; i++) {
		dp[i] = 0;
	}
  	dp[0]=1;
	for (ll i = 0; i < N; i++) {
		for (ll j = 10000; j >= 0; j--) {
			if (dp[j]&&a[i] + j <= 10000)
              dp[j + a[i]] =1;
			}
    }
  	ll x;
  	string ans="impossible";
	for (ll i = 0; i <=10000; i++) {
		if (dp[i])
          x=i;
      	if(sum==2*x){
          ans="possible";
          break;
        }
    }
      cout<<ans<<endl;
}
            
            
            
        