Submission #1013342

#TimeUsernameProblemLanguageResultExecution timeMemory
1013342vjudge1Bank (IZhO14_bank)C++17
25 / 100
3 ms600 KiB
#include <bits/stdc++.h>
#define ll long long int
using namespace std;
#pragma GCC optimize("Ofast")
void YES()
{
    cout<<"YES\n";
}
void NO()
{
    cout<<"NO\n";
}
vector<ll> b;
ll n,m;
ll calc(ll mask)
{
	ll answer = 0;
	for (ll e = 0;e<m;e++)
	{
		if ((1 << e) & mask) answer += b[e];
	}
	return answer;
}
void ans()
{
	cin>>n>>m;
	vector<ll> a(n);
	b = vector<ll>(m);
	vector<bool> dp((1 << m));
	vector<ll> pref(n+1);
	for (ll e = 0;e<n;e++)
	{
		cin>>a[e];
		pref[e] = (e > 0 ? pref[e-1] : 0) + a[e];
	}
	pref[n] = 1e18;
	for (ll e = 0;e<m;e++)
	{
		cin>>b[e];
	}
	dp[0] = 1;
	for (ll len = 0;len < m;len++)
	{
		for (ll mask = 0;mask < (1 << m);mask++)
		{
			if (__builtin_popcount(mask) != len || !dp[mask]) continue;
			// cout<<mask<<" ";
			ll S = calc(mask);
			ll next = 0;
			for (ll i = 0;i<=n;i++)
			{
				if (pref[i] > S)
				{
					next = i;
					break;
				}
			}
			// cout<<S<<" "<<next<<"\n";
			for (ll pos = 0;pos<m;pos++)
			{
				if (!((1 << pos) & mask) && b[pos]+S <= pref[next])
				{
					dp[mask ^ (1 << pos)] = 1;
				}
			}
		}
	}
	if (dp[(1 << m)-1]) YES();
	else NO();
}
int main()
{
    cin.tie(0);cout.tie(0);
    ios_base::sync_with_stdio(0);
	ll t = 1;
	for (ll e = 1;e<=t;e++)
	{
		ans();
	}
    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...