#include <stdio.h>#include <string.h>void search(int k,int ans);int a[25];bool b[25];int flag; int n,k;int main(){ while(scanf("%d%d",&n,&k)!=EOF) { flag=1; memset(b,0,sizeof(b)); for(int i=0;i<n;i++) scanf("%d",&a[i]); search(0,0); if(flag) //没有找到答案就输出NO,我原先想把search函数写成bool类型的, printf("NO\n"); //后来发现用标记更简单,以后要多学习学习 } return 0;}void search(int num,int ans){ if(!flag) return; if(ans==k) { if(num!=0) { flag=0; printf("YES\n"); for(int i=0;i<n;i++) { if(b[i]) { printf("%d ",a[i]); } } printf("\n"); return ; } } for(int i=num;i<n;i++) { if(ans+a[i]<=k) { b[i]=1; search(i+1,ans+a[i]); b[i]=0; } } return ;}