Submission #1306320

#TimeUsernameProblemLanguageResultExecution timeMemory
1306320yusifmTable Tennis (info1cup20_tabletennis)C++20
9 / 100
3096 ms2604 KiB
#pragma GCC optimize("O3")
#include <bits/stdc++.h>
#define ll long long
#define str string
#define pb push_back
#define pf push_front
#define in insert
#define all(v) v.begin(),v.end()
const int sz=1000000,INF=1000000000;
using namespace std;
bool f(vector<ll>nums)
{
    ll sum=0;
    bool flag1=false,flag2=false,flag3=false;
    set<ll>Nums;
    map<ll,ll>counts;
    for(int i=0;i<nums.size();i++)
    {
        sum+=nums[i];
    }
    if(sum%(nums.size()/2)==0)
    {
        for(int i=0;i<nums.size();i++)
        {
            if(nums[i]>sum/(nums.size()/2))
            {
                flag1=true;
                break;
            }
        }
        if(!flag1)
        {
            for(int i=0;i<nums.size();i++)
            {
                Nums.in(nums[i]);
            }
            for(auto num:Nums)
            {
                if(Nums.find(sum/(nums.size()/2)-num)==Nums.end())
                {
                    flag2=true;
                    break;
                }
            }
            if(!flag2)
            {
                for(int i=0;i<nums.size();i++)
                {
                    counts[nums[i]]++;
                }
                for(int i=0;i<nums.size();i++)
                {
                    if(nums[i]!=sum/(nums.size()/2)-nums[i])
                    {
                        if(counts[nums[i]]!=counts[sum/(nums.size()/2)-nums[i]])
                        {
                            flag3=true;
                            break;
                        }
                    }
                    else
                    {
                        if(counts[nums[i]]%2!=0)
                        {
                            flag3=true;
                            break;
                        }
                    }
                }
                if(!flag3)
                {
                    return true;
                }
                else
                {
                    return false;
                }
            }
            else
            {
                return false;
            }
        }
        else
        {
            return false;
        }
    }
    else
    {
        return false;
    }
}
void solve()
{
    ll n,m,num;
    cin>>n>>m;
    vector<ll>nums,ans;
    for(int i=0;i<n+m;i++)
    {
        cin>>num;
        nums.pb(num);
    }
    for(int i=1;i<pow(2,nums.size());i++)
    {
        ans.clear();
        for(int j=0;j<nums.size();j++)
        {
            if(i&(ll)pow(2,j))
            {
                ans.pb(nums[j]);
            }
        }
        if(ans.size()==nums.size()-m)
        {
            if(f(ans))
            {
                break;
            }
        }
    }
    for(int i=0;i<ans.size();i++)
    {
        cout<<ans[i]<<" ";
    }
}
int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr),cout.tie(nullptr);
    ll t=1;
    //cin>>t;
    while(t--)
    {
        solve();
    }
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...