Advertisement
Guest User

Untitled

a guest
Mar 21st, 2019
52
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 0.59 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2.  
  3. using namespace std;
  4.  
  5. int n, k;
  6.  
  7. vector<int> v;
  8.  
  9. int mn;
  10.  
  11. void rek(int indx, int cnt, int sum)
  12. {
  13. if (indx == n)
  14. return;
  15.  
  16. if (sum == k && cnt < mn)
  17. mn = cnt;
  18.  
  19. rek(indx + 1, cnt + 1, sum + v[indx]);
  20.  
  21. rek(indx + 1, cnt, sum);
  22. }
  23.  
  24. int main()
  25. {
  26. int t;
  27. cin >> t;
  28. while(t--)
  29. {
  30. mn = INT_MAX;
  31. int x;
  32. cin >> n >> k;
  33. for (int i = 0; i < n; i++)
  34. {
  35. cin >> x;
  36. v.push_back(x);
  37. }
  38. rek(0, 0, 0);
  39.  
  40. if (mn == INT_MAX)
  41. cout << "impossible\n";
  42. else
  43. cout << mn << '\n';
  44.  
  45. v.clear();
  46. }
  47.  
  48.  
  49. return 0;
  50. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement