結果
問題 |
No.4 おもりと天秤
|
ユーザー |
![]() |
提出日時 | 2017-10-11 14:17:01 |
言語 | C (gcc 13.3.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 504 bytes |
コンパイル時間 | 1,552 ms |
コンパイル使用メモリ | 28,416 KB |
実行使用メモリ | 8,740 KB |
最終ジャッジ日時 | 2024-11-17 09:38:26 |
合計ジャッジ時間 | 55,911 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 14 TLE * 9 |
ソースコード
#include <stdio.h> int n, i, ans, a[100], dp[101][5001] = { 0 }; int solve(int i, int m) { if (dp[i][m] != 0) return dp[i][m]; if (m == 0) dp[i][m] = 1; else if (i >= n) dp[i][m] = 0; else if (solve(i + 1, m) || solve(i + 1, m - a[i])) dp[i][m] = 1; else dp[i][m] = 0; return dp[i][m]; } int main(void) { scanf("%d", &n); for (i = 0; i<n; i++) { scanf("%d", &a[i]); ans += a[i]; } if (ans % 2 == 0&& solve(0, ans / 2)) printf("possible\n"); else printf("impossible\n"); return 0; }