This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include"bits/stdc++.h"
using namespace std;
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds;
template<class x>
using ordered_set = tree<x, null_type,less<x>, rb_tree_tag,tree_order_statistics_node_update>;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
bool plc[600000];
long long occ[600000],a[505];
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
long long n,sum=0;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>a[i];
sum+=a[i];
}
plc[0]=true;
vector <int> h;
vector <int> yes;
yes.push_back(0);
for(int i=0;i<n;i++)
{
for(int j=(int)yes.size()-1;j>=0;j--)
{
if(((yes[j] + a[i] < 600000) and plc[yes[j]+a[i]]!=true)||(yes[j]+a[i])<=250000){
plc[yes[j]+a[i]]=true;
yes.push_back(yes[j]+a[i]);
}
}
}
//cout<<"HI"<<endl;
if(plc[sum/2])
{
for(int k=0;k<n;k++)
{
sum-=a[k];
for(int i=0;i<=250000;i++)
plc[i]=false;
plc[0]=true;
yes.clear();
yes.push_back(0);
for(int i=0;i<n;i++)
{
if(i==k)
continue;
for(int j=(int)yes.size()-1;j>=0;j--)
{
if(((yes[j] + a[i] < 600000) and plc[yes[j]+a[i]]!=true)||(yes[j]+a[i])<=250000){
plc[yes[j]+a[i]]=true;
yes.push_back(yes[j]+a[i]);
}
}
}
//cout<<"HELLO"<<endl;
for(int i=0;i<=sum;i++)
{
long long oth=i-(sum-i);
if(oth<=0)
continue;
if(i < 600000 and plc[i]){
if (oth < 600000) occ[oth]++;
//cout<<oth<<" ";
}
}
//cout<<endl;
sum+=a[k];
}
}
for(int i=1;i<=500000;i++)
{
if(occ[i]==n){
//cout<<"???"<<endl;
h.push_back(i);
}
}
cout<<h.size()<<"\n";
for(auto i : h)
cout<<i<<" ";
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |