Submission #1098198

#TimeUsernameProblemLanguageResultExecution timeMemory
1098198vjudge1Bank (IZhO14_bank)C++17
71 / 100
1066 ms20564 KiB
// Bolatulu
#include <bits/stdc++.h>

typedef long long ll;
typedef unsigned long long ull;
typedef double db;
#define kanagattandirilmagandiktarinizdan ios_base::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
#define pb push_back
#define pf push_front
#define eb emplace_back
#define ins insert
#define F first
#define S second
#define fx cout << fixed << setprecision(6);
#define md (tl+tr)/2
#define TL v+v, tl,md
#define TR v+v+1, md+1,tr
#define Tl t[v].l, tl,md
#define Tr t[v].r, md+1,tr
#define yes cout << "YES\n"
#define no cout << "NO\n"
#define all(x) (x).begin(), (x).end()
#define int ll
#define cnk(n,k) mod(mod(f[(n)]*binpow(f[(n)-(k)],M-2))*binpow(f[(k)],M-2))
#define cnkf(n,k) mod(mod(f[(n)]*inv[(n)-(k)])*inv[(k)])

using namespace std;

typedef complex<double> cd;

struct mine{int l;int r;int i;};
struct edge{int u;int v;int w;};
struct tree{int l;int r;int val;};

auto cmp = [](mine a, mine b) { return a.i<b.i; };

mt19937 RR((uint32_t)chrono::steady_clock::now().time_since_epoch().count());
 
int random(int l, int r){
  return uniform_int_distribution<int>(l, r)(RR);
}

int M=998244353;

int mod1(int a,int b=M) {
    if (a<0)
        a=b+a%b;
    return a % b;
}

int binpow(int a,int n,int m=M) {
    a=mod1(a,m);
    if (!n)
        return 1;
    if (n&1)
        return (a * binpow(a,n-1))%m;
    int x = binpow(a,n>>1);
    return (x*x)%m; 
}

const ll INF=1e18+7;
const int N=2e6+7;

int n,m,a[N],b[N],sum[N],f;
set <int> s[101];
map <int,vector <int>> mp;

void rec1(int x,int y=0,int i=0) {
    if (i>=m) {
        if (s[f+f+1].find(y)!=s[f+f+1].end())
            s[f].insert(x+y);
        return;
    }
    rec1(x,y,i+1);
    if (!(x>>i&1))
        rec1(x,y+(1<<i),i+1);
}

void rec(int v,int l,int r) {
    if (l==r) {
        for (auto now : mp[a[l]])
            s[v].insert(now);
        return;
    }
    int mid=(l+r)/2;
    rec(v+v,l,mid), rec(v+v+1,mid+1,r);
    if (s[v+v].size()>s[v+v+1].size())
        swap(s[v+v],s[v+v+1]);
    // cout << v << endl;
    for (auto now : s[v+v]) {
        f=v;
        rec1(now);
    }
}

void solve() {
    cin >> n >> m;
    for (int i=1;i<=n;i++)
        cin >> a[i];
    for (int i=1;i<=m;i++)
        cin >> b[i];
    for (int i=0;i<(1<<m);i++) {
        sum[i]=0;
        for (int j=0;j<m;j++) {
            if (i>>j&1) {
                sum[i]=sum[i^(1<<j)]+b[j+1];
                break;
            }
        }
        mp[sum[i]].pb(i);
    }
    rec(1,1,n);
    if (!s[1].empty())
        yes;
    else
        no;
}   

signed main() {
    /*
    freopen("sequence.in", "r", stdin);
    freopen("sequence.out", "w", stdout);
    */
    // fx
    kanagattandirilmagandiktarinizdan
    int test = 1, count = 1;
    // cin >> test;
    while (test--) {
        // cout << "Case " << count << ":\n";
        solve();
        if (test) {
            cout << '\n';
            count++;
        }
    }
    return 0;
}

// ctrl + shift + p make stress isis__Good isis__Generator

// g++ -std=c++17 (path) -o run
// .\run
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...