【剑指Offer面试题】 九度OJ1371:最小的K个数
题目链接地址:
http://ac.jobdu.com/problem.php?pid=1371
题目1371:最小的K个数
时间限制:1 秒内存限制:32 兆特殊判题:否提交:5938解决:1265
题目描写叙述:
输入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 4
4 5 1 6 2 7 3 8
例子输出:
1 2 3 4
思路分析:
这题方法非常多,也是面试easy问的问题。
1. 快排后,取出前k个元素。
这种时间复杂度为O(nlogn+k),空间复杂度O(1)。
2. 用map直接统计每一个值出现的次数。
然后数出最小的k个值就可以。空间复杂度O(n)。
3. 採用小顶堆,n个元素建成一个小顶堆,将堆顶与数组的最后一个元素交换。这样最小的元素就保存在了数组的最后一个位置,k次调整后,最小的k个元素便保存在了数组的最后k个位置。时间复杂度为O(n+klogn);改变输入数组,空间复杂度为O(1),不改变输入数组空间复杂度为O(n)。
4. 用最大堆来存k个数,剩下的n-k个数每一个都和堆顶比較,比堆顶小时。就把堆顶元素替换掉。
採取先pop()后push()的方法替换。时间复杂度为O(k+(n-k)logk)。空间复杂度O(k)。(适合海量数据处理)
代码
方法四代码:
优先队列就是大顶堆。队头元素最大。
http://www.cppblog.com/darren/archive/2009/06/09/87224.html
/*********************************
【剑指Offer面试题】 九度OJ1371:最小的K个数
Author:牧之丶 Date:2015年
Email:bzhou84@163.com
**********************************/
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <cstring>
#include <math.h>
#include <stack>
#include <vector>
#include <queue>
#include <iostream>
#include<algorithm>
#include <map>
#include <queue>
using namespace std;
int main()
{
// 大顶堆
priority_queue<int, vector<int>, less<int> > pQueue;
vector<int> result;
int n, k;
int i, tmp;
while(scanf("%d%d", &n, &k)!=EOF){
while(!pQueue.empty()){
pQueue.pop();
}
result.clear();
if(k > n){
k = n;
}
for(i = 0; i < k; ++i){
scanf("%d", &tmp);
pQueue.push(tmp);
}
for(i = k; i < n; ++i){
scanf("%d", &tmp);
if(tmp < pQueue.top()){
pQueue.pop();
pQueue.push(tmp);
}
}
while(!pQueue.empty()){
result.push_back(pQueue.top());
pQueue.pop();
}
for(i = (int)result.size() - 1; i >= 0; --i){
if(i == (int)result.size() - 1){
printf("%d", result[i]);
}else{
printf(" %d", result[i]);
}
}
printf("\n");
result.clear();
}
return 0;
}
/**************************************************************
Problem: 1371
Language: C++
Result: Accepted
Time:980 ms
Memory:2292 kb
****************************************************************/
【剑指Offer面试题】 九度OJ1371:最小的K个数的更多相关文章
- 【剑指offer】求一组数据中最小的K个数
题目:输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. *知识点:Java PriorityQueue 调整新插入元素 转自h ...
- 《剑指offer》— JavaScript(29)最小的K个数
最小的K个数 题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4. 思路一 使用JavaScript的Array对象的so ...
- 剑指Offer - 九度1371 - 最小的K个数
剑指Offer - 九度1371 - 最小的K个数2013-11-23 15:45 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是 ...
- 剑指Offer:面试题15——链表中倒数第k个结点(java实现)
问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...
- 剑指offer——面试题15:二进制中 1的个数
// 面试题15:二进制中1的个数 // 题目:请实现一个函数,输入一个整数,输出该数二进制表示中1的个数.例如 // 把9表示成二进制是1001,有2位是1.因此如果输入9,该函数输出2. #inc ...
- 剑指offer 面试题. 二叉搜索树的第k个结点
题目描述 给定一棵二叉搜索树,请找出其中的第k小的结点.例如, (5,3,7,2,4,6,8) 中,按结点数值大小顺序第三小结点的值为4. 解: 由于二叉搜索树的中序遍历是升序,所以在中 ...
- 九度 1371 最小的K个数
题目描述:输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 输入: 每个测试案例包括2行:第一行为2个整数n,k(1<= ...
- 【剑指Offer面试题】 九度OJ1389:变态跳楼梯
转自:http://www.myexception.cn/program/1973966.html 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2331解决:1332 题目描述: 一只青蛙一次 ...
- 【剑指Offer面试题】 九度OJ1518:反转链表
与其非常快写出一段漏洞百出的代码,倒不如细致分析再写出鲁棒的代码. 提前想好測试用例(输入非空等等)进行測试改动代码. 题目链接地址: http://ac.jobdu.com/problem.php? ...
随机推荐
- STM32 HAL库使用中断实现串口接收不定长数据
以前用DMA实现接收不定长数据,DMA的方法接收串口助手的数据,全部没问题,不过如果接收模块返回的数据,而这些数据如果包含回车换行的话就会停止接收,例如接收:AT\r\nOK\r\n,就只能接收到AT ...
- Ajax原理-重点
Ajax原理 AJAX即“Asynchronous Javascript And XML”,是指一种创建交互式网页应用的网页开发技术.AJAX 是一种用于创建快速动态网页的技术.它可以令开发者只向服务 ...
- java源码之TreeMap
Map的单元是对键值对的处理,之前分析过的两种Map,HashMap和LinkedHashMap都是用哈希值去寻找我们想要的键值对,优点是理想情况下O(1)的查找速度. 那如果我们在一个对查找性能要求 ...
- Spring中 @Autowired标签与 @Resource标签 的区别(转)
spring不但支持自己定义的@Autowired注解,还支持由JSR-250规范定义的几个注解,如:@Resource. @PostConstruct及@PreDestroy. 1. @Autowi ...
- Qt之二维码扫描
简述 二维码(QR Code)是用某种特定的几何图形按一定规律在平面(二维方向)分布的黑白相间的图形记录数据符号信息的.是所有信息数据的一把钥匙.应用十分广泛,如:产品防伪/溯源.广告推送.网站链接. ...
- 电脑显示U盘,可是读取不了
问题: 我的一个内存卡没用,放到了读卡器上.刚開始能用,可是到了后来,突然之间发现: 插入读卡器之后,仅仅是在U下角显示有有U盘提示,提示"打开设备和打印"或者"安全删除 ...
- 哈理工2015暑假训练赛 zoj 2078Phone Cell
Phone CellTime Limit:10000MS Memory Limit:32768KB 64bit IO Format:%lld & %llu SubmitStatus ...
- dexposed框架Android在线热修复
移动client应用相对于Webapp的最大一个问题每次出现bug,不能像web一样在server就完毕修复,不须要发版本号.紧急或者有安全漏洞的问题, 假设是Webapp你可能最多花个1,2个小时紧 ...
- IE input X 去掉文本框的叉叉和password输入框的眼睛图标
IE input X 去掉文本框的叉叉和password输入框的眼睛图标 从IE 10開始,type="text" 的 input 在用户输入内容后.会自己主动产生一个小叉叉(X) ...
- bzoj3442: 学习小组(费用流好题)
3442: 学习小组 题目:传送门 题解: 超级好题啊大佬们的神题!建图肥肠灵性!感觉自己是星际玩家... 首先呢st直接向每个人连边,容量为min(k,喜欢的小组个数),费用为0 然后每个人再向ed ...