結果

問題 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;
      |            ^

ソースコード

diff #

#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;
}











0