题意:
data:image/s3,"s3://crabby-images/74f0e/74f0e7baa4af4568fb7084942364b70438dd6cc3" alt=""
思路:
data:image/s3,"s3://crabby-images/0f227/0f227f133df65246190bb6ce945ce72cb32ff721" alt=""
data:image/s3,"s3://crabby-images/df150/df1509f007cc8c41fefed6d20d978b28b396d8b8" alt=""%E7%8E%B0%E5%9C%A8%E8%BD%AE%E5%88%B0%E6%94%BE%E7%AC%ACi%E4%B8%AA%E7%89%A9%E5%93%81%EF%BC%8C%E5%B7%B2%E7%BB%8F%E7%94%A8%E4%BA%86j%E4%B8%AA%E5%88%86%E7%BB%84%EF%BC%8C%E9%82%A3%E4%B9%88%E7%89%A9%E5%93%81i%E5%A6%82%E6%9E%9C%E6%94%BE%E5%BE%97%E4%B8%8B%EF%BC%8C&preview=true)
data:image/s3,"s3://crabby-images/18eba/18ebae948dd87c44a9ec284e0b581861588562f9" alt=""
data:image/s3,"s3://crabby-images/873d2/873d262c5912c21baf1f7e72db3cd4978b44040d" alt=""
#include <cstdio>
#include <algorithm>
using namespace std;
const int N = 25;
const int inf = 0x3f3f3f3f;
int a[N],w[N],ans,n,x,W,mx;
void dfs(int x,int cnt){
if(cnt >= ans) return;
if(x > n){
ans = min(ans,cnt);
return;
}
for(int i = 0;i < cnt;i++){
if(w[i] + a[x] <= W){
w[i] += a[x];
dfs(x + 1,cnt);
w[i] -= a[x];
}
}
w[cnt] = a[x];
dfs(x + 1,cnt + 1);
w[cnt] = 0;
}
int main(){
int t;scanf("%d",&t);
while(t--){
mx = -inf;
scanf("%d%d%d",&n,&x,&W);
for(int i = 1;i <= n;i++){
scanf("%d",a + i);
mx = max(mx,a[i]);
}
if(mx > W){puts("No");continue;}
sort(a + 1,a + 1 + n,greater<int>());
ans = n;
dfs(1,1);
if(ans <= x) puts("Yes");
else puts("No");
}
}