이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#define ff first
#define ss second
#define ll int
#define TIME  (1.0 * clock() / CLOCKS_PER_SEC)
 ll n,m,a[21],b[21],res,kt[10010];
 void dao(ll i)
 {
     for (ll j=1;j<=n;j++)
        if (a[j]>=b[i])
      {
         a[j]-=b[i];
         if (a[j]==0) res--;
         if (m-i>=res)
         {
          if (i==m)
          {if (res==0){cout<<"YES";exit(0);}}
          else dao(i+1);
         }
         if (a[j]==0) res++;
        a[j]+=b[i];
     }
 }
int main()
{
  
    ios_base :: sync_with_stdio(0);
    cin.tie(0),cout.tie(0);
    cin>>n>>m;
    for (ll i=1;i<=n;i++)
    cin>>a[i],kt[a[i]]++;
    for (ll i=1;i<=m;i++)
    {
    cin>>b[i];
    if (kt[b[i]]>0) kt[b[i]]--,i--,m--;
    }
    vector<ll> c;
    for (ll i=1;i<=n;i++)
    {
    if (kt[a[i]]>0) c.push_back(a[i]);
    kt[a[i]]--;
    }
    n=0;
    for (ll j:c)
    a[++n]=j;
    n++;
    a[n]=100010;
    res=n-1;
    dao(1);
    cout<<"NO";
}
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... |