// 最小的k个数.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include <iostream>
#include <set>
#include <vector>
#include <queue>
using namespace std; // set中默认是从大到小的顺序,即最先取出的是最小值
// 此处为从小到大,最先取出的是最大值
typedef multiset<int,greater<int>> inSet;
typedef multiset<int,greater<int>>::iterator setIterator; // 基于红黑树
void GetNumber(vector<int> &data,inSet &leastNumber,int k)
{
if(k<= || data.size()==)
return ;
leastNumber.clear();
vector<int>::iterator it = data.begin();
for(;it!=data.end();++it)
{
if(leastNumber.size()<k)
leastNumber.insert(*it);
else{
setIterator s = leastNumber.begin(); if(*it < *s)
{
leastNumber.erase(s);
leastNumber.insert(*it);
}
}
}
setIterator s = least.begin();
for(;s!=least.end();++s)
cout<<*s<<" ";
cout<<endl;
} // 基于优先队列
void GetNumber2(vector<int> &data,int k)
{
if(data.size()== || k<)
return ;
// top取出的是最小值,即是按从大到小排列的
//priority_queue<int,vector<int>,greater<int>> q;
// 默认是从小到大排列,即最先取出的是最大值
priority_queue<int> q;
vector<int>::iterator it = data.begin();
for(;it!=data.end();++it)
{
if(q.size()<k)
q.push(*it);
else{
if(*it < q.top())
{
q.pop();
q.push((*it));
}
}
}
while(q.size()>)
{
cout<<q.top()<<" ";
q.pop();
}
cout<<endl;
} int Partition(int *a,int start,int end)
{
if(start < end)
{
int i=start,j=end;
int x = a[start];
while(i<j)
{
while(i<j && a[j]>x)
j--;
if(i<j)
a[i++] = a[j];
while(i<j && a[i]<x)
i++;
if(i<j)
a[j--] = a[i];
}
a[i] = x;
return i;
}
} // 基于分治思想,但会修改数组,时间复杂度为O(N)
void GetNumber2(int *a,int len,int k)
{
if(a==NULL || len<= || k<=)
return ;
int start = ,end = len-;
int index = Partition(a,start,end);
//取出最小的K个数
while(index != k-)
{
if(index < k-)
{
start = index +;
index = Partition(a,start,end);
}else{
end = index -;
index = Partition(a,start,end);
}
}
for(int i=;i<k;++i)
cout<<a[i]<<" ";
cout<<endl;
} int _tmain(int argc, _TCHAR* argv[])
{
vector<int> v;
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
inSet least;
GetNumber1(v,least,); GetNumber2(v,); int a[]={,,,,,,,};
GetNumber2(a,,); system("pause");
return ;
}

最小的k个数的更多相关文章

  1. 剑指Offer面试题:27.最小的k个数

    一.题目:最小的k个数 题目:输入n个整数,找出其中最小的k个数.例如输入4.5.1.6.2.7.3.8这8个数字,则最小的4个数字是1.2.3.4. 这道题是典型的TopK问题,其最简单的思路莫过于 ...

  2. 算法练习:寻找最小的k个数

    参考July的文章:http://blog.csdn.net/v_JULY_v/article/details/6370650 寻找最小的k个数题目描述:查找最小的k个元素题目:输入n个整数,输出其中 ...

  3. 剑指Offer:面试题30——最小的k个数(java实现)

    问题描述: 输入n个整数,找出其中最小的k个数 思路1: 先排序,再取前k个 时间复杂度O(nlogn) 下面给出快排序的代码(基于下面Partition函数的方法) public void Quic ...

  4. 输入一个数组,求最小的K个数

    被这道题困了好久,看了剑指Offer才知道OJ上的要求有点迷惑性. 题目: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4. 一 ...

  5. 1046: 最小的K个数

    1046: 最小的K个数 时间限制: 1 Sec  内存限制: 128 MB提交: 233  解决: 200[提交][状态][讨论版] 题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1 ...

  6. 最小的K个数:用快排的思想去解相关问题

    实现快速排序算法的关键在于先在数组中选择一个数字,接下来把数组中的数字分为两部分,比选择的数字小的数字移到数组的左边,比选择的数字大的数字移到数组的右边. 这个函数可以如下实现: int Partit ...

  7. 剑指offer面试题30:最小的k个数

    一.题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 二.解题思路 1.思路1 首先对数组进行排序,然后取出前k个数 ...

  8. 窥探算法之美妙——寻找数组中最小的K个数&python中巧用最大堆

    原文发表在我的博客主页,转载请注明出处 前言 不论是小算法或者大系统,堆一直是某种场景下程序员比较亲睐的数据结构,而在python中,由于数据结构的极其灵活性,list,tuple, dict在很多情 ...

  9. 求一个数组中最小的K个数

    方法1:先对数组进行排序,然后遍历前K个数,此时时间复杂度为O(nlgn); 方法2:维护一个容量为K的最大堆(<算法导论>第6章),然后从第K+1个元素开始遍历,和堆中的最大元素比较,如 ...

随机推荐

  1. Azure开发者任务之六:使用WCF Service Web Role

    在本文中,我们将会在local development fabric上创建一个WCF服务角色,然后在一个控制台应用程序中使用它. WCF服务角色可以让我们创建一个WCF服务,并且把它托管在Window ...

  2. 线段树或树状数组---Flowers

    题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=4325 Description As is known to all, the blooming tim ...

  3. custom struts framework

    1. Difference between stucts1 and struts2 struts1 : Servlet used as Controller , you can visit the S ...

  4. Hibernate框架之Criteria查询

    首先给大家说说Hibernate检索方式 Hibernate提供了5种检索对象的方式 1.导航对象图检索方式:根据已经加载的对象导航到其他对象 2.OID检索方式:按照对象的OID来检索对象 3.HQ ...

  5. Linux初学者指南

    1.为啥我们要学习Linux? 我们干嘛要学习Linux? Linux能给我们带来什么价值呢? Linux给我的感觉就是稳定,免费,性能好. 稳定,体现在哪里?我们使用PC机,安装的操作系统一般是wi ...

  6. Angular 核心概念

    module(模块) 作用 通过模块对页面进行业务上的划分,根据不同的功能划分不同的模块. 将重复使用的指令或者过滤器之类的代码做成模块,方便复用 注意必须指定第二个参数,否则变成找到已经定义的模块 ...

  7. 如何查询拥有执行某个Tcode权限所有人员

    方法很简单,如下 一:Tcode:S_BCE_68001400二:输入你想查询的Tcode,例如:SE38   打开如下图所示,然后执行即可   三:AUTH(关于权限的控制),打开如下图所示.上图“ ...

  8. ABAP 表格控制(Table Control)和步循环

    表格控制(Table Control)和步循环     1.两个标准Demo: SAPMTZ60,SAPMTZ61 2.简介 3.建立Table Control程序的基本流程 4.使用步循环 5.表格 ...

  9. NLog 自定义字段 写入 oracle

    1.通过Nuget安装NLog 下载,简单入门 请参照 我刚才转的几篇文章,下面我直接贴代码 2.建表语句 create table TBL_LOG ( id ) not null, appname ...

  10. hadoop实战–搭建eclipse开发环境及编写Hello World

    原创文章,转载请注明: 转载自工学1号馆 欢迎关注我的个人博客:www.wuyudong.com, 更多云计算与大数据的精彩文章 1.在eclise中安装hadoop的插件并配置 在上篇文章<编 ...