QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#819419#4414. Divide the SweetsKevin5307AC ✓10669ms52068kbC++232.1kb2024-12-18 15:27:312024-12-18 15:27:41

Judging History

你现在查看的是最新测评结果

  • [2024-12-18 15:27:41]
  • 评测
  • 测评结果:AC
  • 用时:10669ms
  • 内存:52068kb
  • [2024-12-18 15:27:31]
  • 提交

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