传送门

Description

Input

Output

Translation

·  给定k个长度为k的数组,把每个数组选一个元素加起来,这样共有kk种可能的答案,求最小的k个

Sample Input


Sample Output

 

Hint

k<=750

Solution

  显然可以一行一行做,同时如果S+now[j]最小,需要S最小。即我们只需要记录前i行的最小的k个ans,分别与当前行的k个相加,从k2个ans中选择前k个小的记录。显然前k小的可以开一个大根堆维护。即如果size>k则pop。这样一共有k次转移,每次转移有k2个状态,维护k的堆的复杂度为Logk,这样总复杂度为O(k3logk)

  易于通过数学归纳证明取第i行的最小的只需要与前i-1行最小的k个ans相加得到。这样我们不妨用数组ans记录前i行最小的k个ans,现在我们考虑我们有两个数组a,b,需要取k个ans最小。不妨设a和b都是有序的,我们显然有如下关系:

  a1+b1≤a1+b2≤a1+b3≤a1+b4≤……≤a1+bk

  a2+b1≤a2+b2≤a2+b3≤a2+b4≤……≤a2+bk

  ……

  ak+b1≤ak+b2≤ak+b3≤ak+b4≤……≤ak+bk

这样显然ai+bj可能成为前k小的ans当且仅当ai+bj-1是前k小的ans。

我们维护一个可能成为ans的序列,每次取这个序列中最小,显然最小值可以成为合法的ans。同时不妨设这个值为ai+bj,那么我们将ai+bj+1压入序列,因为它可能成为合法的ans。

初始化上,因为ai+b1可能成为合法的ans,我们将这k个全部压入队列中。

Code

#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 1010 inline void qr(int &x) {
char ch=getchar(),lst=NULL;
while(ch>''||ch<'') lst=ch,ch=getchar();
while(ch>=''&&ch<='') x=(x<<)+(x<<)+(ch^),ch=getchar();
if(lst=='-') x=-x;
} template <typename T>
inline T mmax(const T &a,const T &b) {if(a>b) return a;return b;}
template <typename T>
inline T mmin(const T &a,const T &b) {if(a<b) return a;return b;}
template <typename T>
inline T mabs(const T &a) {if(a>=) return a;return -a;} template <typename T>
inline void mswap(T &a,T &b) {T temp=a;a=b;b=temp;} int k,MU[maxn],ans[maxn]; struct Zay {
int v,s;
Zay(int a=,int b=) {v=a;s=b;}
inline bool operator <(const Zay &others) const{return this->v>others.v;}
}; std::priority_queue<Zay>Q;
void clear(); int main() {
while(~scanf("%d",&k)) {
clear();
for(int i=;i<=k;++i) qr(ans[i]);
for(int i=;i<=k;++i) {
memset(MU,,sizeof MU);
for(int j=;j<=k;++j) {
qr(MU[j]);
}
std::sort(MU+,MU++k);
while(!Q.empty()) Q.pop();
for(int j=;j<=k;++j) {
Q.push(Zay(ans[j]+MU[],));
}
for(int j=;j<=k;++j) {
Zay temp=Q.top();Q.pop();
ans[j]=temp.v;
if(temp.s<k) Q.push(Zay(temp.v-MU[temp.s]+MU[temp.s+],temp.s+));
}
}
for(int i=;i<k;++i) printf("%d ",ans[i]);printf("%d\n",ans[k]);
}
return ;
} void clear() {
memset(ans,,sizeof ans);
}

Summary

在堆的应用中,维护一坨可能合法的解进行操作,是一种常用的思路。比如本题和dijkstra算法都是这个思路。这一坨合法的解一般满足下面两个条件:

第一,这坨解中最大/小的解一定是合法的解。比如本题中,序列中最小的一定是合法的解,dijkstra算法中,堆中权值和最小的解一定是到该点的最短路等等

第二,通过寻找合法解,可以获得其他可能解。比如在本题中,ai+bj合法时,ai+bj+1是可能解。在dijkstra算法中,找到到一个点的最短路可以更新和它相邻的点的可能最短路压入堆中。

【优先队列】【UVa11997】K Smallest Sums的更多相关文章

  1. 【暑假】[实用数据结构]UVa11997 K Smallest Sums

    UVa11997 K Smallest Sums  题目: K Smallest Sums You're given k arrays, each array has k integers. Ther ...

  2. UVA-11997 K Smallest Sums

    UVA - 11997 K Smallest Sums Time Limit: 1000MS   Memory Limit: Unknown   64bit IO Format: %lld & ...

  3. uva11997 K Smallest Sums&&UVALive 3135 Argus(优先队列,多路归并)

    #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #inc ...

  4. UVA11997 K Smallest Sums

    思路 经典的k路归并问题 问题先转换为2路的有序表归并 先让A[1~k]都和B[1]相加,然后加入堆中,取出堆顶(A[x]+B[y])之后,再放入A[x]+B[y+1] 代码 #include < ...

  5. 题解——UVA11997 K Smallest Sums

    题面 背景 输入 输出 翻译(渣自翻) 给定K个包含K个数字的表,要求将其能产生的\( k^{k} \)个值中最小的K个输出出来 题解 k路归并问题的经典问题 可以转化为二路归并问题求解 考虑A[], ...

  6. 11997 - K Smallest Sums(优先队列)

    11997 - K Smallest Sums You’re given k arrays, each array has k integers. There are kk ways to pick ...

  7. UVa 11997 K Smallest Sums 优先队列&amp;&amp;打有序表&amp;&amp;归并

    UVA - 11997 id=18702" target="_blank" style="color:blue; text-decoration:none&qu ...

  8. D - K Smallest Sums(多路归并+贪心)

    Problem K K Smallest Sums You're given k arrays, each array has k integers. There are kk ways to pic ...

  9. 优先队列 UVA 11997 K Smallest Sums

    题目传送门 题意:训练指南P189 分析:完全参考书上的思路,k^k的表弄成有序表: 表1:A1 + B1 <= A1 + B2 <= .... A1 + Bk 表2:A2 + B1 &l ...

随机推荐

  1. Java应用基础微专业-入门篇

    第1章--用程序来做计算 1.1 第一个Java程序 Mac version: Preference -> General -> Keys -> Search "Conte ...

  2. Solr与Elasticsearch区别

    Elasticsearch Elasticsearch是一个实时的分布式搜索和分析引擎.它可以帮助你用前所未有的速度去处理大规模数据. 它可以用于全文搜索,结构化搜索以及分析. 优点 Elastics ...

  3. post接口_form表单上传

    上传文件的本质是浏览器读取本地文件的内容,以二进制数据方式传输到服务端,服务端新建一个文件,将获取到的数据复制到文件中 LR中上传操作可以通过web_submit_data函数实现,支持录制要点:we ...

  4. ionic ios样式偏移解决方案。

    在css属性内增加: .item-ios [item-end] { //解决ios系统上尾部图标出现重影而增加的格式. margin: 0px -15.3px 0px 0px; margin-bott ...

  5. django request bug

    bug描述:django请求request接收数据时,如果参数中包含分号时,会导致分号后面的消息丢失. 比如前台js调用代码 $.post('/get_params', { "A" ...

  6. Kali渗透测试工具-nslookup

    1.交互模式 终端输入nslookup进入交互模式 (1)查询A地址记录(默认) set q=a A记录简单理解将域名转换成对应的IP地址 (2)查询mail exchanger set q=mx m ...

  7. 2.hadoop基本配置,本地模式,伪分布式搭建

    2. Hadoop三种集群方式 1. 三种集群方式 本地模式 hdfs dfs -ls / 不需要启动任何进程 伪分布式 所有进程跑在一个机器上 完全分布式 每个机器运行不同的进程 2. 服务器基本配 ...

  8. 搭建备份到业务迁移---mysql

    mysql安装启动以及配置 使用到阿里云主机直接yum安装以及配置 [root@yunwei-169 mysql]# yum install mysql mysql-server [root@yunw ...

  9. 在linux下PHP和Mysql环境搞事情

    研发部门同事开发了一个接口管理辅助工具Shepherd,要求搭建在内网环境中,遇到点小问题记一下. 将开发的文件上传只web目录下,更改数据库ip,可以正常打开 登陆用户信息,此时需要连接数据库来验证 ...

  10. iOS- <项目笔记>项目配置常见文件

    项目常见文件 1.main.m * 里面有一个程序的入口:main函数 2.Prefix.pch文件 * pch文件中的内容能被项目中的其他任何文件共享\包含\访问 * 如果定义的内容只用在OC环境中 ...