結果

問題 No.4 おもりと天秤
ユーザー ikdikd
提出日時 2015-11-06 13:14:11
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 866 bytes
コンパイル時間 489 ms
コンパイル使用メモリ 63,292 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-09-13 13:01:06
合計ジャッジ時間 1,344 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
6,812 KB
testcase_01 AC 2 ms
6,944 KB
testcase_02 AC 2 ms
6,940 KB
testcase_03 AC 2 ms
6,940 KB
testcase_04 WA -
testcase_05 WA -
testcase_06 AC 2 ms
6,940 KB
testcase_07 WA -
testcase_08 AC 2 ms
6,944 KB
testcase_09 AC 2 ms
6,940 KB
testcase_10 WA -
testcase_11 AC 1 ms
6,940 KB
testcase_12 AC 2 ms
6,940 KB
testcase_13 AC 1 ms
6,940 KB
testcase_14 AC 2 ms
6,944 KB
testcase_15 AC 2 ms
6,940 KB
testcase_16 WA -
testcase_17 AC 1 ms
6,940 KB
testcase_18 AC 2 ms
6,940 KB
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<iostream>
#include<stdio.h>
#include<vector>
#include<algorithm>

using namespace std;


int n;
vector<int> w;
int dp[101][101];

int rec(int i, int j){
    if(dp[i][j]!=-1){
        return dp[i][j];
    }

    int res;

    if(i==n){
        res = 0;
    }else if(j<w[i]){
        res = rec(i+1, j);
    }else{
        res = max(rec(i+1, j), rec(i+1, j-w[i])+w[i]);
    }

    dp[i][j] = res;
    return res;
}

int main(){

    fill_n((int*)dp, 101*101, -1);

    cin>> n;
    int a, sum = 0;
    for(int i=0; i<n; i++){
        cin>> a;
        w.push_back(a);
        sum += w[i];
    }

    int W;
    if(sum%2==1){
        cout<< "impossible"<< endl;
        return 0;
    }else{
        W = sum/2;
    }

    int ans = rec(0, W);
    if(ans==W){
        cout<< "possible"<< endl;
    }else{
        cout<< "impossible"<< endl;
    }

    return 0;
}
0