結果

問題 No.4 おもりと天秤
ユーザー ikdikd
提出日時 2015-11-06 12:47:55
言語 C++11
(gcc 11.4.0)
結果
TLE  
実行時間 -
コード長 718 bytes
コンパイル時間 413 ms
コンパイル使用メモリ 60,124 KB
実行使用メモリ 7,520 KB
最終ジャッジ日時 2023-10-11 14:20:35
合計ジャッジ時間 6,970 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

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

using namespace std;


int n;
vector<int> w;

int rec(int i, int 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]);
    }

    return res;
}

int main(){

    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