题目描述
给定m个序列,每个序列包含n个非负整数。现在我们可以从每个序列中选择一个数字以形成一个具有m个整数的序列。显然,我们可以得到n ^ m种这种序列。然后,我们可以计算每个序列中的数字总和,并获得n ^ m个值。我们需要的是最小的n个和。你可以帮我们吗?

题目大意:给定M个长度为N的序列,从每个序列中任意取一个数求和,可以构成N的M次方个和,求其中最小的N个和。

输入格式
第一行是整数T,它显示测试用例的数量,然后是T个测试用例。每种情况的第一行都包含两个整数m,n(0 <m <= 100,0 <n <= 2000)。以下m行分别表示m序列。序列中没有整数大于10000。

输出格式
对于每个测试用例,按升序打印具有最小n个和的行,并用空格隔开。

样例
样例输入
1
2 3
1 2 3
2 2 3
样例输出
3 3 4
数据范围与提示
POJ月刊,广林
题目分析
1.因为要求是打印前n小的,所以,我们可以给每一个序列先排个序
这样我们就可以累加每一个序列的首位,这个就是第一小的数,然后
我们就要找到第二小的
2.如果我们假设m=2;,则第二小的数在(a[2]+b[1)(a[1]+b[2])中,如果选择(a[2]+b[1])那么,第三小的在(a[3]+b[1]),(a[2]+b[2])(a[1]+b[2])中,。。。。
如果选择(a[k]+b[l],那么后面一小的在a[k+1]+b[l],a[k][l+1],与前面的剩余部分
最后求出以个长度n的序列,a,b便和并了,以同样的道理,和并一共m-1次
3.所以,我们可以建立一个小根堆,放入每一个要选择的和,每一次去取树根
4因为有重复的可能所以要用以个bool数组用巧妙的方法限制

#include<bits/stdc++.h>
using namespace std;
int Heap_size;
int n,m,T;
int a[2005],b[2005],c[2005];
struct ss{
int st1,st2,zs,pd;
}Heap[2005],st,aa;
void Put_heap(ss x)
{ Heap[++Heap_size]=x;
int now=Heap_size;
while(now>1&&Heap[now].zs<Heap[now>>1].zs)
{
swap(Heap[now],Heap[now>>1]);
now>>=1;
}
}
void Get_heap()
{
Heap[1]=Heap[Heap_size--];
int fa=1;
while(fa<=Heap_size/2)
{
int son=fa*2;
if(Heap_size>son&&Heap[son].zs>Heap[son+1].zs)
{
son++;
}
if(Heap[fa].zs>Heap[son].zs)
{
swap(Heap[fa],Heap[son]);
}
else
{
break;
}
fa=son;
} }
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d %d",&m,&n);
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
}
sort(a+1,a+1+n);
for(int i=1;i<m;i++)
{
Heap_size=0;
for(int j=1;j<=n;j++)
{
scanf("%d",&b[j]);
} sort(b+1,b+1+n); st.st1=1;
st.st2=1;
st.pd=0;
st.zs=a[1]+b[1];
Put_heap(st);
for(int j=1;j<=n;j++)
{
st=Heap[1];
Get_heap();
c[j]=st.zs;
if(!st.pd)
{ aa.st1=st.st1+1;
aa.st2=st.st2;
aa.pd=0;
aa.zs=a[aa.st1]+b[aa.st2];
Put_heap(aa);
aa.st1=st.st1;
aa.st2=st.st2+1;
aa.zs=a[aa.st1]+b[aa.st2];
aa.pd=1;
Put_heap(aa);
}
else
{
aa.st1=st.st1;
aa.st2=st.st2+1;
aa.pd=1;
aa.zs=a[aa.st1]+b[aa.st2];
Put_heap(aa);
}
}
for(int j=1;j<=n;j++) a[j]=c[j];
}
for(int i=1;i<=n;i++) printf("%d ",a[i]);
printf("\n"); } }

POJ 2442 Sequence堆 优先队列的更多相关文章

  1. POJ 2442 Sequence(堆的使用练习)

    题目地址:id=2442">POJ 2442 真心没想到这题的思路. .原来是从第一行逐步向下加,每次都仅仅保存前n小的数.顺便练习了下堆.. 只是感觉堆的这样的使用方法用的不太多啊. ...

  2. poj 2442 Sequence(优先队列)

    题目:http://poj.org/problem?id=2442 题意:给你n*m的矩阵,然后每行取一个元素,组成一个包含n个元素的序列,一共有n^m种序列, 让你求出序列和最小的前n个序列的序列和 ...

  3. poj 2442 Sequence (Priority Queue)

    2442 -- Sequence 真郁闷,明明方法是对的,为什么我的代码老是那么的慢._(:з」∠)_ 这题要想考虑两列的情况,然后逐列拓展. 代码如下: #include <cstdio> ...

  4. POJ 2442 - Sequence - [小顶堆][优先队列]

    题目链接:http://poj.org/problem?id=2442 Time Limit: 6000MS Memory Limit: 65536K Description Given m sequ ...

  5. POJ 2442 Sequence【堆】

    题目链接:http://poj.org/problem?id=2442 题目大意:给出一个m*n的矩阵,从每一行中取出一个数相加.能得到n^m个不同的结果.要求输出当中前n项. 建立一个以n元数组为底 ...

  6. POJ 2442 Sequence 优先队列

    题目: http://poj.org/problem?id=2442 #include <stdio.h> #include <string.h> #include <q ...

  7. POJ 2442 Sequence

    Pro. 1 给定k个有序表,取其中前n小的数字.组成一个新表,求该表? 算法: 由于  a1[1] < a1[2] < a1[3] ... <a1[n] a2[1] < a2 ...

  8. Sequence POJ - 2442

    Sequence POJ - 2442 口胡一个结论:就是前i行产生的最小的n个和,一定可以在"前i-1行产生的最小n个和,每一个加上这一行的任意一个数,产生的n2个数"中找到.( ...

  9. poj 3253 Fence Repair 优先队列

    poj 3253 Fence Repair 优先队列 Description Farmer John wants to repair a small length of the fence aroun ...

随机推荐

  1. 【Linux】【Services】【MessageQueue】搭建高可用rabbitMQ

    1. 简介 1.1. 官方网站: https://www.rabbitmq.com/ 1.2. 配置文档:https://docs.openstack.org/ha-guide/shared-mess ...

  2. FastJson简介

    FastJson简介 首先,介绍一下fastjson.fastjson是由alibaba开源的一套json处理器.与其他json处理器(如Gson,Jackson等)和其他的Java对象序列化反序列化 ...

  3. 解决Spring MVC @ResponseBody出现问号乱码问题

    原因是SpringMVC的@ResponseBody使用的默认处理字符串编码为ISO-8859-1,而我们前台或者客户端的编码一般是UTF-8或者GBK.现将解决方法分享如下! 第一种方法: 对于需要 ...

  4. 【MySQL】亲测可用的教程筛选:安装与卸载

    windows版本的 安装看这篇,非常详细:https://www.cnblogs.com/winton-nfs/p/11524007.html 彻底清除:https://www.pianshen.c ...

  5. 网络通信引擎ICE的使用

    ICE是一种网络通信引擎,在javaWeb的开发中可以用于解决局域网内部服务器端与客户端之间的网络通信问题.即可以在 1.在服务器和客户端都安装好ICE 2.服务器端(java)在java项目中引入I ...

  6. LightningChart .NET v.10.2.1已经发布了!

    LightningChart .NET v.10.2.1已经发布了! 了解更多关于兼容性和优化方面的最新改进. 主要改进 我们很高兴地宣布LightningChart .NET产品系列的第三个主要版本 ...

  7. Android系统编程入门系列之硬件交互——多媒体展示

    前两篇文章通过麦克风硬件和摄像头硬件分别采集音频和视频的多媒体数据,在得到的多媒体数据通常是以编码文件的格式存储,在用户需要展示时,可通过设备的内置扩音器或蓝牙耳机等硬件播放音频,通过设备的显示屏或外 ...

  8. ciscn_2019_ne_5

    首先checksec和查看多少位的程序 可以看到是32位的程序,放入ida中 进入getflag 可以看到strcpy存在栈溢出,所以大体思路就是输入密码进入选择1造成溢出然后进入选择4获取shell ...

  9. 使用bochs调试汇编程序

    使用bochs调试汇编程序 前面我们已经搭建好了bochs的环境,并且将我们的汇编程序写入了硬盘里面,现在我们来看看如何通过bochs来调试我们的程序. 前文:https://www.cnblogs. ...

  10. pdf文件在线预览

    使用pdfjs技术实现PDF的在线预览功能. 目录 1.官网下载pdf.js 2. 将下载下来的文件全部复制 3. js使用 4. java IO流 1.官网下载pdf.js 2. 将下载下来的文件全 ...