第三章:寻找最小的k个数

寻找最小的k个数
题目描述:5.查找最小的k个元素
题目:输入n个整数,输出其中最小的k个。
例如输入1,2,3,4,5,6,7和8这8个数字,则最小的4个数字为1,2,3和4。

堆实现可见:简洁的heap代码

#include <iostream>
#include <windows.h>
#include <algorithm>
#include <numeric>
#include <string>
#include <array>
#include <vector>
#include <functional>
#include <hash_set>
#include <ctime>
using namespace std;

#define N 20//最大的N个数
//第一种方法,维护N+1个元素的小顶堆
//O(NlogK)
void f1(){
	//freopen("C:\\in.txt","r",stdin);
	vector<int> t(10000);
	srand((unsigned)time(NULL));
	generate(t.begin(),t.end(),[](){return rand()%10000;});
	
	make_heap(t.begin(),t.begin()+N+1,greater<int>());
	for(auto it=t.begin()+N+1;it!=t.end();){
		push_heap(t.begin(),t.begin()+N+1,greater<int>());
		pop_heap(t.begin(),t.begin()+N+1,greater<int>());
		it=t.erase(t.begin()+N);
	}
	for_each(t.begin(),t.end(),[](int i){cout<<i<<endl;});
}
//第二种方法:整个建堆,pop K次
//O(N+KlogN)
void f2(){
	vector<int> t(1000000);
	srand((unsigned)time(NULL));
	generate(t.begin(),t.end(),[](){return rand()%10000;});
	
	make_heap(t.begin(),t.end());//对所有元素建大顶堆
	for(int i=0;i<N;i++){
		cout<<t.front()<<endl;
		pop_heap(t.begin(),t.end());
		t.pop_back();
	}
}
void Test(){
	f2();
}
int main()    
{    
    LARGE_INTEGER BegainTime ;    
    LARGE_INTEGER EndTime ;    
    LARGE_INTEGER Frequency ;    
    QueryPerformanceFrequency(&Frequency);    
    QueryPerformanceCounter(&BegainTime) ;    
    
    //要测试的代码放在这里   
    Test();   
     
    QueryPerformanceCounter(&EndTime);   
    
    //输出运行时间(单位:s)   
    cout << "运行时间(单位:s):" <<(double)( EndTime.QuadPart - BegainTime.QuadPart )/ Frequency.QuadPart <<endl;    
    
    //system("pause") ;    
    return 0 ;    
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值