QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#819419 | #4414. Divide the Sweets | Kevin5307 | AC ✓ | 10669ms | 52068kb | C++23 | 2.1kb | 2024-12-18 15:27:31 | 2024-12-18 15:27:41 |
Judging History
answer
//Author: Kevin
#include<bits/stdc++.h>
#pragma GCC optimize("unroll-loops")
//#pragma GCC optimize("O2")
using namespace std;
#define ll long long
#define ull unsigned ll
#define pb emplace_back
#define mp make_pair
#define ALL(x) (x).begin(),(x).end()
#define rALL(x) (x).rbegin(),(x).rend()
#define srt(x) sort(ALL(x))
#define rev(x) reverse(ALL(x))
#define rsrt(x) sort(rALL(x))
#define sz(x) (int)(x.size())
#define inf 0x3f3f3f3f
#define pii pair<int,int>
#define lb(v,x) (int)(lower_bound(ALL(v),x)-v.begin())
#define ub(v,x) (int)(upper_bound(ALL(v),x)-v.begin())
#define uni(v) v.resize(unique(ALL(v))-v.begin())
#define longer __int128_t
void die(string S){puts(S.c_str());exit(0);}
ll dp[21][1<<20];
ll w[1<<20];
int a[20];
inline void upd(ll &a,ll b){if(b<a)a=b;}
ll f[1<<20],g[1<<20];
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int t;
cin>>t;
while(t--)
{
int n,m;
cin>>n>>m;
for(int i=0;i<n;i++)
cin>>a[i];
for(int i=0;i<(1<<n);i++)
{
w[i]=0;
for(int j=0;j<n;j++) if(i>>j&1) w[i]+=a[j];
w[i]*=w[i];
}
if(n>12)
{
for(int i=0;i<(1<<n);i++)
f[i]=g[i]=1ll*inf*inf;
for(int i=1;i<(1<<n);i++)
for(int j=i;j+j>=i;j=(j-1)&i)
f[i]=min(f[i],w[j]+w[i^j]);
f[0]=0;
g[0]=0;
for(int i=1;i<(1<<n);i++)
for(int j=i;j+j+j>=i+i;j=(j-1)&i)
g[i]=min(g[i],f[j]+w[i^j]);
for(int i=1;i<=m;i++)
{
ll *val;
if(i==1) val=w;
if(i==2) val=f;
if(i==3) val=g;
ll ans=0;
for(int j=0;j<(1<<n);j++)
ans+=val[j];
cout<<ans%998244353<<'\n';
}
continue;
}
for(int i=0;i<(1<<n);i++)
for(int j=0;j<=m;j++)
dp[j][i]=1ll*inf*inf;
dp[0][0]=0;
for(int i=0;i<(1<<n);i++)
for(int r=i;;r=(r-1)&i)
{
int a=__builtin_popcount(r);
int b=__builtin_popcount(i);
for(int j=0;j<m&&a*j+a<=b;j++)
upd(dp[j+1][i],dp[j][r^i]+w[r]);
if(!r) break;
}
for(int i=1;i<=m;i++)
{
ll ans=0;
for(int j=0;j<(1<<n);j++)
ans+=dp[i][j];
cout<<ans%998244353<<'\n';
}
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 10669ms
memory: 52068kb
input:
50 1 1 41157 2 2 42567 45459 3 3 18704 43514 6548 4 4 17662 19185 22570 28320 5 5 12535 20205 16505 10400 35580 6 6 35939 41496 10203 32740 30192 13030 7 7 30302 23454 8704 15004 27743 15952 25399 8 8 12327 33605 17303 14647 34972 28109 40172 49588 9 9 32280 30113 13060 40035 2051 45364 40615 40351 ...
output:
695654296 646358963 769229869 54472802 405484871 160537287 823590338 851657132 637283444 957836857 395450630 690615709 828346439 712250445 451522445 474027871 483702848 709934365 891371356 230636443 962990616 766698146 57439143 791362845 395411395 400364705 706984356 445794724 187302962 250823365 77...
result:
ok 479 lines