fork download
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4. int main()
  5. {
  6. int t,n,i,j,k;
  7. cin>>t;
  8. while(t--)
  9. {
  10. cin>>n>>k;
  11. int a[n];
  12. for(i=0;i<n;i++)
  13. cin>>a[i];
  14. int cnt,mn=INT_MAX;
  15. int sum=0;
  16. for(i=0;i<1<<n;i++)
  17. {
  18. sum=0;
  19. cnt=0;
  20. for(j=0;j<n;j++)
  21. {
  22. if(i&1<<j)
  23. {sum+=a[j];++cnt;}
  24. }
  25. if(sum==k)
  26. mn=min(mn,cnt);
  27. }
  28. if(mn==INT_MAX)
  29. cout<<"impossible\n";
  30. else
  31. cout<<mn<<"\n";
  32. }
  33. // your code goes here
  34. return 0;
  35. }
Success #stdin #stdout 0s 16064KB
stdin
2
5 9
10 9 4 3 5
3 7
1 2 3
stdout
1
impossible