Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
141929 | 李树强 | 简单背包问题 | C++ | 解答错误 | 60 | 0 MS | 252 KB | 553 | 2024-04-06 14:55:54 |
#include<iostream> using namespace std; const int N = 40; int s, n, a[N], cnt = 0; bool res[N], flag = false; void f(int x){ if(s == cnt){ for(int i = 0; i < n; i++){ if(res[i]) cout << a[i] << endl; } flag = true; return; } if(x == -1){ return; } cnt += a[x]; res[x] = true; f(x - 1); cnt -= a[x]; if(flag) return; res[x] = false; f(x - 1); if(flag) return; } int main(){ cin >> s >> n; for(int i = 0; i < n; i++){ cin >> a[i]; } f(n-1); if(!flag) cout << "Failed!"; return 0; }