Advertisement
ismaeil

How to Work Less to Pass a Programming Course in Planet E-13

Jan 7th, 2021
145
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.42 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4. const int N = 20;
  5. vector< int > p;
  6. int n ,g;
  7.  
  8. int main()
  9. {
  10.     scanf("%d%d" ,&n ,&g);  p.resize(n);
  11.     for(auto &i : p)    scanf("%d" ,&i);
  12.  
  13.     int totalPoint = 0 ,numOfElement = 0 ,Sum = 0; {
  14.         vector< int > tmp = p;
  15.         sort(tmp.begin() ,tmp.end() ,greater< int >());
  16.         for(auto i : tmp) totalPoint += i;
  17.  
  18.         for(auto i : tmp)
  19.         {
  20.             Sum += i;
  21.             numOfElement += 1;
  22.  
  23.             if( 100 * Sum / totalPoint >= g ) break;
  24.         }
  25.     }
  26.  
  27.     vector< vector< int > > Ans;
  28.     for(int Mask = 0 ; Mask <= (1 << n) ; Mask += 1)
  29.     {
  30.         int tmpMask = Mask;
  31.         vector< int > idx;
  32.  
  33.         while( tmpMask )
  34.         {
  35.             int fd = (tmpMask & -tmpMask);
  36.             idx.push_back( log2(fd) );
  37.             tmpMask -= fd;
  38.         }
  39.  
  40.  
  41.         if( (int)idx.size() == numOfElement )
  42.         {
  43.             Sum = 0;
  44.             for(auto i : idx) Sum += p[i];
  45.  
  46.             if( 100 * Sum / totalPoint >= g )
  47.             {
  48.                 Ans.push_back( vector< int >() );
  49.                 Ans.back().push_back(100 * Sum / totalPoint);
  50.                 for(auto i : idx) Ans.back().push_back(i + 1);
  51.             }
  52.         }
  53.     }
  54.  
  55.     printf("%d %d\n" ,numOfElement ,(int)Ans.size());
  56.     for(auto i : Ans){
  57.         for(auto j : i)
  58.             printf("%d " ,j);
  59.         puts("");
  60.     }
  61.     return 0;
  62. }
  63.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement