九度OJ 题目1371:最小的K个数
- 题目描述:
 - 
输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。
 
- 输入:
 - 
每个测试案例包括2行:
第一行为2个整数n,k(1<=n,k<=200000),表示数组的长度。
第二行包含n个整数,表示这n个数,数组中的数的范围是[0,1000 000 000]。
 
- 输出:
 - 
对应每个测试案例,输出最小的k个数,并按从小到大顺序打印。
 
- 样例输入:
 - 
8 44 5 1 6 2 7 3 8
 
- 样例输出:
 - 
1 2 3 4
思路:
面对如此规模的n,k采用一般方法肯定会超时的,我们维护一个K个元素的最大堆,(前K个元素初始化建堆),然后每次读入一个元素,就和堆顶元素相比较
如果该元素比堆顶元素大,那么跳过,否则更新堆顶元素,并调整堆,这样一遍之后,我们得到了最小的K个元素构成的最大堆,再排序即可。
代码:
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cstdio>
using namespace std;
const int MAX=200001;
int min_k[MAX];
void heap_adj(int *a,int i,int len)
{
int index=i*2;
int p=2*i,q=p+1;
if(q<=len && a[p]<a[q]) index=q;
if(index<=len && a[i]<a[index])
{
swap(a[i],a[index]);
heap_adj(a,index,len);
}
}
void makeheap(int *a,int len)
{
for(int i=len/2;i>=1;i--)
heap_adj(a,i,len);
}
int main()
{
int n,k;
while(cin>>n>>k)
{
for(int i=1;i<=k;i++)
scanf("%d",&min_k[i]);
makeheap(min_k,k);
for(int i=k+1;i<=n;i++)
{
int tmp;
scanf("%d",&tmp);
if(tmp<min_k[1]){
min_k[1]=tmp;
heap_adj(min_k,1,k);
}
}
sort(min_k+1,min_k+1+k);
for(int i=1;i<k;i++) cout<<min_k[i]<<" ";
cout<<min_k[k]<<endl;
}
return 0;
} 
九度OJ 题目1371:最小的K个数的更多相关文章
- 九度oj  题目1087:约数的个数
		
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
 - 九度oj题目1207:质因数的个数
		
题目描述: 求正整数N(N>1)的质因数的个数. 相同的质因数需要重复计算.如120=2*2*2*3*5,共有5个质因数. 输入: 可能有多组测试数据,每组测试数据的输入是一个正整数N,(1&l ...
 - 九度oj 题目1207:质因数的个数
		
题目描述: 求正整数N(N>1)的质因数的个数. 相同的质因数需要重复计算.如120=2*2*2*3*5,共有5个质因数. 输入: 可能有多组测试数据,每组测试数据的输入是一个正整数N,(1&l ...
 - 剑指Offer - 九度1371 - 最小的K个数
		
剑指Offer - 九度1371 - 最小的K个数2013-11-23 15:45 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是 ...
 - hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
		
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
 - 九度oj题目&吉大考研11年机试题全解
		
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
 - 九度oj 题目1007:奥运排序问题
		
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
 - 九度OJ 题目1384:二维数组中的查找
		
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
 - 九度OJ 1371 最小的K个数 -- 堆排序
		
题目地址:http://ac.jobdu.com/problem.php?pid=1371 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4 ...
 
随机推荐
- Windows SVN变化邮件通知(Python2.7实现)
			
1,新增文件post-commit.bat 内容: rem REPOS-PATH (the path to this repository) set REPOS=%1 rem REV (the num ...
 - Linux开机禁用开启防火墙
			
1.# chkconfig --list:显示开机可以自动启动的服务 结果:iptables 0:off 1:off 2:on 3:on 4:on 5:on ...
 - Linux进程笔记
			
进程及作业管理 Uninterruptible sleep: 不可中断的睡眠Interruptible sleep:可中断睡眠 kernel:init: COW: Copy On Write, 写时复 ...
 - Java 获取Linux 的IP地址
			
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ...
 - 利用Python完成一个小游戏:随机挑选一个单词,并对其进行乱序,玩家要猜出原始单词
			
一 Python的概述以及游戏的内容 Python是一种功能强大且易于使用的编程语言,更接近人类语言,以至于人们都说它是“以思考的速度编程”:Python具备现代编程语言所应具备的一切功能:Pytho ...
 - ExtJS+ASP.NET自己定义曲线
			
第一步:创建Store数据源 var myData = []; myData.push({ 'name': '1', 'Oil_Production': '30', 'Water_Injection' ...
 - LINQ to SQL和Entity Framework对照
			
LINQ to SQL和Entity Framework都是一种包括LINQ功能的对象关系映射技术.他们之间的本质差别在于EF对数据库架构和我们查询的类型实行了更好的解耦. 使用EF,我们查询的对象不 ...
 - 基于Vue 和 webpack的项目实现
			
Vue.js 是一款极简的 mvvm 框架,如果让我用一个词来形容它,就是 “轻·巧” .如果用一句话来描述它,它能够集众多优秀逐流的前端框架之大成,但同时保持简单易用.废话不多说,来看几个例子: & ...
 - mysql1主多从配置
			
mysql一主多从的配置: 其实1主多从的配置与一主一从配置非常相似,现在主要讲讲一主多从的大概配置方法. 一, 1,master端开启binlog日志,并且设置server id=1. 2.重启服务 ...
 - CSS学习笔记——CSS中定位的浮动float
			
昨天在解决了盒模型的问题之后又出现了新的知识模糊点:浮动和绝对定位?今天先解决浮动相关的问题,首先列举出想要解决的问题: 1.浮动到底是怎么样的? 2.浮动对元素的影响有什么? 3.浮动主要用来干什么 ...