Submission #884894

#TimeUsernameProblemLanguageResultExecution timeMemory
884894xuvxuvBank (IZhO14_bank)C++14
0 / 100
1103 ms348 KiB
#include<bits/stdc++.h> using namespace std; #define int long long #define rep(i,a,b) for(auto i=a;i<b;i++) #define all(x) x.begin(),x.end() #define vpii vector<pair<int,int>> typedef pair<int,int> pii; typedef vector<int> vi; typedef map<int,int> mii; const int Prime1= 1000000007; const int Prime2= 998244353; long long binpow(long long a, long long b, long long m) { a %= m; long long res = 1; while (b > 0) { if (b & 1){ res = res * a % m;} a = a * a % m; b >>= 1; } return res; } vector<int> hp(int n){ vector<int>h(n,0) ; for(int i=2;i<n;i++){ h[i]=i; } for( int i=2;i*i<n;i++){ if(h[i]==i){ for(int j=i;j<n;j+=i){ h[j]=i; } } } return h; } int n,m; int a[21]; int b[21]; int tar; vi v; bool f(int mask){ int val=0; for(int i=0;i<m;i++){ if(mask&(1<<i)){ val+=b[i]; } } if(val==tar)return 1; auto it = upper_bound(all(v),val); int req= *it-val; bool ans=0; for(int i=0;i<m;i++){ if((mask&(1<<i))==0){ if(b[i]<=req){ ans|=f(mask|(1<<i)); } } } return ans; } signed main(){ ios_base::sync_with_stdio(false); cin.tie(NULL); cin>>n>>m; tar=0; for(int i=0;i<n;i++){ cin>>a[i]; tar+=a[i]; if(i==0){ v.push_back(a[i]); } else { v.push_back(a[i]+v.back()); } } v.clear(); for(int i=0;i<m;i++){ cin>>b[i]; } bool ans= f(0); if(ans){ cout<<"YES\n"; } else { cout<<"NO\n"; } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...