結果
問題 | No.4 おもりと天秤 |
ユーザー |
![]() |
提出日時 | 2015-04-25 16:36:42 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 6 ms / 5,000 ms |
コード長 | 790 bytes |
コンパイル時間 | 210 ms |
コンパイル使用メモリ | 23,424 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-26 09:10:59 |
合計ジャッジ時間 | 1,068 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:26:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 26 | scanf("%d",&N); | ~~~~~^~~~~~~~~ main.cpp:29:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 29 | scanf("%d",&W[i]); | ~~~~~^~~~~~~~~~~~
ソースコード
#include <stdio.h> int memo[101][5001],done[101][5001]; int N,W[100],s; int max(int a,int b){ if(a>b){return a;}else{return b;} } int dp(int a,int b){ if(done[a][b] == 1){return memo[a][b];} memo[a][b] = 0; if(b+W[a]<=s){ memo[a][b] = dp(a+1,b+W[a]); } memo[a][b] = max(memo[a][b],dp(a+1,b)); done[a][b] = 1; return memo[a][b]; } int main(void){ int i,j; scanf("%d",&N); s = 0; for(i=0;i<N;i++){ scanf("%d",&W[i]); s = s + W[i]; } if(s%2 == 1){ printf("impossible\n"); return 0; } s = s/2; for(i=0;i<N;i++){ for(j=0;j<s;j++){ done[i][j] = 0; } } for(i=0;i<=N;i++){ done[i][s] = 1; memo[i][s] = 1; } for(i=0;i<s;i++){ done[N][i] = 1; memo[N][i] = 0; } if(dp(0,0) == 1){ printf("possible\n"); }else{ printf("impossible\n"); } }