一  问题描述:

找出 m 个整数中第 k(0<k<m+1)大的整数。


二  举例:

假设有 12 个整数:data[1, 4, -1, -4, 9, 8, 0, 3, -8, 11, 2, -9],请找出第 5 大的数(容易知道是0)。


三   算法思路:

       一种基于快排思想的算法可以在 O(n) 复杂度内找到第k大的数,首先要知道 partition 这个函数,它可以调整一个序列

使小于 key 的元素都排在 key 左边,大于 key 的元素都排在 key 右边,key 可以在这个序列中任意选择,一般选择给定序

列的首元素。

partition函数的一般形式:

 int  partition (int * data, int low, int high)

       其中 low 和 high 分别是给定下标的上下边界。

先举例说明,调用 partition (data,  1,  8),就是要将 data 中从 data[1] 到 data[8] 之间的序列分为两部分

       截取的序列:data[2] -- data[8],为  4, -1, -4, 9, 8, 0, 3, -8

       key 选取第一个数:  key = 4 

       调用 partition(data,  2,  8) 后,这个序列变为: -8, -1, -4, 3, 0,      4,      8, 9

       需要注意的是,data[1] 到 data[8] 这个序列片段在原来 data[0] 到 data[11] 这个大序列中已经发生改变,而其他

       没有截取到的片段保持不变。

      

       partition 的算法步骤如下:

       1     设置两个下标left和right,left = low,right = high

              此时left指向4,也是key元素,right指向-8

               4, -1, -4, 9, 8, 0, 3, -8

       2    从right开始寻找一个小于key的数,它是-8,找到后将它赋值给left所在位置

              4, -1, -4, 9, 8, 0, 3, -8    --找到是-8

              -8, -1, -4, 9, 8, 0, 3, -8   --赋值到4的位置,

              注意key元素4在这些步骤之前就已经保存

       3     从left开始寻找一个比key大的元素,它是9,把它赋值给right所在位置

               -8, -1, -4, 9, 8, 0, 3, -8   --找到是9

               -8, -1, -4, 9, 8, 0, 3, 9   --赋值到-8的位置

             重复步骤2,再次从right开始寻找一个小于key的数,它是3,将它赋值给left所在位置     

                -8, -1, -4, 9, 8, 0, 3,  9   --找到是3

                -8, -1, -4, 3, 8, 0, 3,  9   --赋值到9的位置

             重复步骤3,再次从left开始寻找一个大于key的数,它是8,将它赋值到right指向的位置          

               -8, -1, -4, 3, 8, 0, 3,  9   --找到是8

               -8, -1, -4, 3, 8, 0, 8,  9   --赋值到3的位置

            重复步骤2,再次从right开始寻找一个小于key的数,它是0,将它赋值给left所在位置   

             -8, -1, -4, 3, 8, 0, 8,  9   --找到是0

             -8, -1, -4, 3, 0, 0, 8,  9   --赋值8的位置

           重复步骤3,再次从left开始寻找一个大于key的数,现在left指向0,left++后,会发现left == right,

            所以现在要退出循环,并把key元素赋值为left所在位置       

-8, -1, -4, 3, 0, 4, 8,  9  --完成了最后一步

          

       

       

       

找出整数中第k大的数的更多相关文章

  1. 前端算法题:找出数组中第k大的数字出现多少次

    题目:给定一个一维数组,如[1,2,4,4,3,5],找出数组中第k大的数字出现多少次. 例如:第2大的数是4,出现2次,最后输出 4,2 function getNum(arr, k){ // 数组 ...

  2. 算法题之找出数组里第K大的数

    问题:找出一个数组里面前K个最大数. 解法一(直接解法): 对数组用快速排序,然后直接挑出第k大的数.这种方法的时间复杂度是O(Nlog(N)).N为原数组长度. 这个解法含有很多冗余,因为把整个数组 ...

  3. #7 找出数组中第k小的数

    「HW面试题」 [题目] 给定一个整数数组,如何快速地求出该数组中第k小的数.假如数组为[4,0,1,0,2,3],那么第三小的元素是1 [题目分析] 这道题涉及整数列表排序问题,直接使用sort方法 ...

  4. 215. Kth Largest Element in an Array找出数组中第k大的值

    堆排序做的,没有全部排序,找到第k个就结束 public int findKthLargest(int[] nums, int k) { int num = 0; if (nums.length &l ...

  5. 寻找数列中第k大的数算法分析

    问题描述:给定一系列数{a1,a2,...,an},这些数无序的,现在求第k大的数. 看到这个问题,首先想到的是先排序,然后直接输出第k大的数,于是得到啦基于排序的算法 算法一: #include&l ...

  6. [经典算法题]寻找数组中第K大的数的方法总结

    [经典算法题]寻找数组中第K大的数的方法总结 责任编辑:admin 日期:2012-11-26   字体:[大 中 小] 打印复制链接我要评论   今天看算法分析是,看到一个这样的问题,就是在一堆数据 ...

  7. 查找数组中第k大的数

    问题:  查找出一给定数组中第k大的数.例如[3,2,7,1,8,9,6,5,4],第1大的数是9,第2大的数是8-- 思考:1. 直接从大到小排序,排好序后,第k大的数就是arr[k-1]. 2. ...

  8. 找出数组中出现次数超过一半的数,现在有一个数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数

    找出数组中出现次数超过一半的数,现在有一个数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数 #include<iostream>using namespace s ...

  9. 求数列中第K大的数

    原创 利用到快速排序的思想,快速排序思想:https://www.cnblogs.com/chiweiming/p/9188984.html array代表存放数列的数组,K代表第K大的数,mid代表 ...

随机推荐

  1. BZOJ3439: Kpm的MC密码

    3439: Kpm的MC密码 Time Limit: 15 Sec  Memory Limit: 256 MBSubmit: 166  Solved: 79[Submit][Status] Descr ...

  2. 通过 PowerShell 支持 Azure Traffic Manager 外部端点和权重轮询机制

    Jonathan TulianiAzure网络 - DNS和 Traffic Manager高级项目经理 在北美 TechEd 大会上,我们宣布了 Azure Traffic Manager将支持 ...

  3. 【传】玩转Android---UI篇---ImageButton(带图标的按钮)

    原文网址:http://hualang.iteye.com/blog/964049 除了Android系统自带的Button按钮一万,还提供了带图标的按钮ImageButton 要制作带图标的按钮,首 ...

  4. 关于如何导入GPUImage

    今天是我第一天做项目哈,由于前几天实在是没有很多空,我姐结婚,事情太多,所以今天才开始真正写项目,希望不要太晚. 今天是晚上开始的,预期的计划就是能够把GPUImage成功导入,然后使用一些其中的东西 ...

  5. App被拒绝的原因收录

    转自:dApps开发者 » APP被苹果App Store拒绝的79个原因(未完待续) 1.程序有重大bug,程序不能启动,或者中途退出.2.绕过苹果的付费渠道,我们之前游戏里的用兑换码兑换金币.3. ...

  6. eCos系统CPU负载测量

    原文:http://ecos.sourceware.org/docs-latest/ref/services-cpuload.html 译文:http://blog.csdn.net/zoomdy/a ...

  7. hdu 4742 Pinball Game 3D 分治+树状数组

    离散化x然后用树状数组解决,排序y然后分治解决,z在分治的时候排序解决. 具体:先对y排序,solve(l,r)分成solve(l,mid),solve(mid+1,r), 然后因为是按照y排序,所以 ...

  8. [React + webpack] hjs-webpack

    You can easily spend hours configuring the perfect dev environment with all the latest hotness like ...

  9. android 24 设置与桌面相同的action和category

    设置与桌面相同的action和category 安卓系统桌面也是一个activity,安卓桌面的action和category是: <activity android:name="co ...

  10. [转] Scale-up 和Scale-out的区别

    http://www.cnblogs.com/spork/archive/2009/12/29/1634766.html 来自原小站,曾经迷糊过的东西,表上来,希望对正在迷糊或即将迷糊的人有帮助. 谈 ...