首页 > 其他 > 详细

找到n个元素中的第二小元素

时间:2014-09-30 12:59:49      阅读:219      评论:0      收藏:0      [点我收藏+]


算法导论中的一道习题

证明: 在最坏情况下,找到n个元素中的第二小的元素需要n+ceil(lgn)-2次比较。(提示:可以同时找到最小元素,ceil表示向上取整)

思路:

找到最小元素需要n-1次比较。采用两两结合比较的方法。如果n为奇数,则取第一个元素为临时最小元素min,其它两两结合比较,形成一个类似树的比较过程。如果n为偶数,则直接进行两两结合比较,根节点即为最小元素。

接下来查找第二小元素,需要ceil(lgn)-1次比较。考虑:第二小元素一定和第一小元素进行了比较,所以可以直接在比较树的根节点到叶节点中的元素中去寻找,当n为2^n时,树高为floor(lgn)。否则,树高为ceil(lgn), 需要比较次数为floor(lgn)-1或ceil(lgn)-1     (ps:此处为何只是ceil(lgn)  没搞明白。。。) 

这样就可以得到一个与结论很接近的一个结果。


那么,我们发散一下思维,最坏情况下是上面的结果,那么最好情况下呢?

思路:

“设定两个存储单元:N1,N2,N1中保存最小的两个中较大的一个,N2中保存最小的一个。
 假设前两个数是最小的,比较这两个数,将小的放在N2中,大的放在N1中。
 从第三个开始循环与N1比较,如果当前比较的值大于N1的值,则继续循环直到最后。如果当前比较的值小于N1的值,则与N2做比较,如果大于N2则用当前值替换N1的值,如果小于N2,则用N2的值替换N1的值,当前值替换N2的值。
 这样做法应该是比较最少的了,最少比较:N-1次,最多比较:2N-3次。”


思路有限,如果你有好的想法,请指教!谢谢~


参考:http://bbs.csdn.net/topics/10428265

找到n个元素中的第二小元素

原文:http://blog.csdn.net/chenlei0630/article/details/39693775

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!