[ABC123D] Cake 123

文章讨论了如何在给定三个整数序列A、B和C中,通过优化暴力枚举方法,利用优先队列找到每个序列的前K个元素组合的总和的最大值。关键在于证明如果第K+1大的元素能成为前K大值,那么它前面必然有K个更优元素,从而采用分步处理策略解决问题。
摘要由CSDN通过智能技术生成

Portal.

暴力枚举,时间复杂度 O ( X 3 log ⁡ X 3 ) O(X^3\log X^3) O(X3logX3)

考虑优化,注意到所有的元素都是正的,所以只有 A , B A,B A,B 序列的前 K K K 大值才有可能成为总的前 K K K 大值。

证明:若 A , B A,B A,B 序列的第 K + 1 K+1 K+1 大值能成为总的前 K K K 大值,则它前面一定会有 K K K 个数比它更优。矛盾。

把这 K K K 个值压入优先队列,再枚举 C C C 序列,取前 K K K 大值即可。

#include <bits/stdc++.h>
using namespace std;
#define int long long

int A[1005],B[1005],C[1005];
priority_queue<int> q1,q2;

signed main()
{
	ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
	int X,Y,Z,K;cin>>X>>Y>>Z>>K;
	for(int i=1;i<=X;i++) cin>>A[i];
	for(int j=1;j<=Y;j++) cin>>B[j];
	for(int k=1;k<=Z;k++) cin>>C[k];
	for(int i=1;i<=X;i++)
		for(int j=1;j<=Y;j++) q1.push(A[i]+B[j]);
	for(int i=1;i<=min(K,X*Y);i++)
	{
		int x=q1.top();q1.pop();
		for(int j=1;j<=Z;j++) q2.push(x+C[j]);
	}
	while(K--) cout<<q2.top()<<"\n",q2.pop();
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值