#include<iostream> #include<algorithm> using namespace std; int n,m,a[25]; int solve(int left,int i,int right){ if(i>n+1) return 0; if(left==right) return 1; return solve(left+a[i],i+1,right)||solve(left,i+1,right+a[i])||solve(left,i+1,right); } int main(){ cin>>n>>m; int b; for(int i=0;i<n;i++)cin>>a[i]; while(m--){ cin>>b; if(solve(0,0,b))cout<<"YES"<<endl; else cout<<"NO"<<endl; } return 0; }
解题思路:
注意事项:
参考代码:
0.0分
0 人评分
C语言训练-求矩阵的两对角线上的元素之和 (C语言代码)浏览:619 |
计算质因子 (C++代码)浏览:1824 |
母牛的故事 (C语言代码)浏览:992 |
字符串的输入输出处理 (C语言代码)浏览:1019 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:633 |
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:674 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:559 |
逆反的01串 (C语言代码)浏览:1528 |
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言描述之函数调用)浏览:835 |
【密码】 (C语言代码)浏览:574 |