zoukankan      html  css  js  c++  java
  • 最小的k个数

      1 // 最小的k个数.cpp : 定义控制台应用程序的入口点。
      2 //
      3 
      4 #include "stdafx.h"
      5 #include <iostream>
      6 #include <set>
      7 #include <vector>
      8 #include <queue>
      9 using namespace std;
     10 
     11 //  set中默认是从大到小的顺序,即最先取出的是最小值
     12 //  此处为从小到大,最先取出的是最大值
     13 typedef multiset<int,greater<int>> inSet;
     14 typedef multiset<int,greater<int>>::iterator setIterator;
     15 
     16 //  基于红黑树
     17 void GetNumber(vector<int> &data,inSet &leastNumber,int k) 
     18 {
     19     if(k<=0 || data.size()==0)
     20         return ;
     21     leastNumber.clear();
     22     vector<int>::iterator it = data.begin();
     23     for(;it!=data.end();++it)
     24     {
     25         if(leastNumber.size()<k)
     26             leastNumber.insert(*it);
     27         else{
     28             setIterator s = leastNumber.begin();
     29 
     30             if(*it < *s)
     31             {
     32                 leastNumber.erase(s);
     33                 leastNumber.insert(*it);
     34             }
     35         }
     36     }
     37     setIterator s = least.begin();
     38     for(;s!=least.end();++s)
     39         cout<<*s<<" ";
     40     cout<<endl;
     41 }
     42 
     43 //  基于优先队列
     44 void GetNumber2(vector<int> &data,int k)
     45 {
     46     if(data.size()==0 || k<1)
     47         return ;
     48     //  top取出的是最小值,即是按从大到小排列的
     49     //priority_queue<int,vector<int>,greater<int>> q;
     50     // 默认是从小到大排列,即最先取出的是最大值
     51     priority_queue<int> q;
     52     vector<int>::iterator it = data.begin();
     53     for(;it!=data.end();++it)
     54     {
     55         if(q.size()<k)
     56             q.push(*it);
     57         else{
     58             if(*it < q.top())
     59             {
     60                 q.pop();
     61                 q.push((*it));
     62             }
     63         }
     64     }
     65     while(q.size()>0)
     66     {
     67         cout<<q.top()<<" ";
     68         q.pop();
     69     }
     70     cout<<endl;
     71 }
     72 
     73 int Partition(int *a,int start,int end)
     74 {
     75     if(start < end)
     76     {
     77         int i=start,j=end;
     78         int x = a[start];
     79         while(i<j)
     80         {
     81             while(i<j && a[j]>x)
     82                 j--;
     83             if(i<j)
     84                 a[i++] = a[j];
     85             while(i<j && a[i]<x)
     86                 i++;
     87             if(i<j)
     88                 a[j--] = a[i];
     89         }
     90         a[i] = x;
     91         return i;
     92     }
     93 }
     94 
     95 //  基于分治思想,但会修改数组,时间复杂度为O(N)
     96 void GetNumber2(int *a,int len,int k)
     97 {
     98     if(a==NULL || len<=0 || k<=0)
     99         return ;
    100     int start = 0,end = len-1;
    101     int index = Partition(a,start,end);
    102         //取出最小的K个数
    103     while(index != k-1)
    104     {
    105         if(index < k-1)
    106         {
    107             start = index +1;
    108             index = Partition(a,start,end);
    109         }else{
    110             end = index -1;
    111             index = Partition(a,start,end);
    112         }
    113     }
    114     for(int i=0;i<k;++i)
    115         cout<<a[i]<<" ";
    116     cout<<endl;
    117 }
    118 
    119 
    120 int _tmain(int argc, _TCHAR* argv[])
    121 {
    122     vector<int> v;
    123     v.push_back(1);
    124     v.push_back(3);
    125     v.push_back(9);
    126     v.push_back(2);
    127     v.push_back(3);
    128     v.push_back(8);
    129     v.push_back(6);
    130     inSet least;
    131     GetNumber1(v,least,5);
    132 
    133     GetNumber2(v,5);
    134 
    135     int a[]={3,1,35,65,7,3,8,2};
    136     GetNumber2(a,8,1);
    137 
    138     system("pause");
    139     return 0;
    140 }
    141     
  • 相关阅读:
    Connected Components? Codeforces
    洛谷 P1344 [USACO4.4]追查坏牛奶Pollutant Control
    洛谷 P4174 [NOI2006]最大获利 && 洛谷 P2762 太空飞行计划问题 (最大权闭合子图 && 最小割输出任意一组方案)
    表达式求值
    费用流(自用,勿看)
    二分图??(自用,勿看)
    C 标准库
    Linux-socket使用
    C 标准库
    C 标准库
  • 原文地址:https://www.cnblogs.com/balingybj/p/4748515.html
Copyright © 2011-2022 走看看