美文网首页
计算机经典算法——锦标赛排序算法

计算机经典算法——锦标赛排序算法

作者: cure_py | 来源:发表于2019-08-28 13:19 被阅读0次

关键词:二叉树
生活中的淘汰锦标赛:在单淘汰的锦标赛中,选手们两两比赛,胜者晋级,败者被淘汰。比如世界乒乓球锦标赛或者大满贯网球赛就是这么进行的。
这样一来,就可以把比赛的赛程和结果对应成一个二叉树。在树中每一个选手是二叉树中的一个叶子结点,每一场比赛就相当于两个数字在比大小,数字大的选手获胜进入下一轮,成为树干上的根。所以,进入到某一轮比赛的选手,其实都是某个子数干的根结点。最后的冠军就是整个二叉树的根结点。这种赛制的合理性需要一个假设:A>B, B>C --> 必然有A>C(输赢的传递性)


锦标赛排序法:对所有数字排序,复杂度是nlogn(和快速排序差不多)。特定的场合,它更快,如果只选第一名,则算法复杂度只有N,若需要选出第二名,则额外增加logn就可以了,对第三名也是如此。这种方法在从N个选手中选出K个选手的事情中特别快

工程中,要比较两个数字的大小
第一步:把所有的数字放到二叉树的叶子节点,然后按照锦标赛单淘汰的方式,两两比较选出最大
第二步:对于第二大的,从所有被最大的数字淘汰的数字中选择,以此类推选择对于第三、第四大的数字

高盛面试题

假定有25名短跑选手比赛竞争金银铜牌,赛场上有5条赛道,因此一次可以有5个人同时比赛。比赛不及时,只看相应的名次。假如选手的发挥是稳定的,也就是说如果约翰比张三跑的快,张三比凯利跑的快,那么约翰一定比凯利跑得快。最少需要几组比赛才能决出前3名?

第一步,将25名选手分成5组,每组5人。让每个组分别比赛,排出各组的名次来,假设他们的名字就是他们在小组中的编号。



第二步,让各组的第一名,也就是A1、B1、C1、D1、E1再比一次。假设A1在这次比赛中获胜,这样我们就知道了第一名。



第三步,A2和另外四个组的第一名竞争亚军,A2、B1、C1、D1、E1比一次,假设A2这一次赢了,他就是亚军。如果A2没有赢,另外4个组的某个第一名赢了,那个赢的人是亚军,就由那个组下一位选手递进,角逐第三名


第四步,如上图通过8次(5 +1 + 1 +1)选出的5人进行第三名的比赛,前3全部产生

更好的答案:
前6次比赛都是必须的,最佳答案的前2步和上述方案中的前2步是相同的。在第6组比赛(即5个第一名的比赛)结束之后,最后的2名已经没有资格角逐前3名了。

不妨假设那一次比赛从最快到最慢的结果是A1、B1、C1、D1、E1,在D1和E1之前已经有3名选手了,他们肯定不是前3名。
谁还会是第二名的候选呢?根据锦标赛排序的原则,直接输给第一名的人,也就是A2,以及最后附加赛输给他的B1,仅此两人而已。
谁会是第三名的候选呢?和A1在某一组比赛的第三名,他们是A3、C1,或者输给第二名候选人B1的人,即B2。

因此,第二、第三名的候选人一共只有5个, A2、A3、B1、B2和C1,刚好凑一组。这样加上前6次,只需要赛7组,这是最佳方法。


注:来自吴军老师得到课程

相关文章

  • 计算机经典算法——锦标赛排序算法

    关键词:二叉树生活中的淘汰锦标赛:在单淘汰的锦标赛中,选手们两两比赛,胜者晋级,败者被淘汰。比如世界乒乓球锦标赛或...

  • 经典排序算法总结

    经典排序算法集锦 冒泡法 排序算法入门之冒泡排序 排序算法入门之冒泡排序优化

  • 算法学习(1)-排序算法

    八大排序算法九大排序算法再总结[经典排序算法][集锦][直观学习排序算法] 视觉直观感受若干常用排序算法 快速排序...

  • 序言-算法

    此文集将介绍一些经典的算法,从经典的排序算法开始不定期的补充纠错更新 1、经典排序算法 1.1桶排序Bucket ...

  • 十大经典排序算法&七大查找算法

    十大经典排序算法: 十大经典排序算法的时间、空间复杂度: 冒泡排序(Bubble Sort) 算法描述: 1、比较...

  • 2018-06-30

    排序算法之归并排序 归并排序算法是排序算法中的经典算法之一,其核心思想是利用归并的思想实现的排序方法,该算法采用经...

  • Swift的十大经典排序算法总结

    Swift的十大经典排序算法总结 排序算法是《数据结构与算法》中最基本的算法之一。排序算法可以分为内部排序和外部排...

  • 用 Python 实现十大经典排序算法

    今天,详细的跟大家分享下 10 种经典排序算法。 10种经典排序算法包括冒泡排序、选择排序、快速排序、归并排序、堆...

  • 一文搞定十大经典排序算法(Java实现)

    本文总结十大经典排序算法及变形,并提供Java实现。参考文章:十大经典排序算法总结(Java语言实现)快速排序算法...

  • 常用排序算法总结(C++实现)

    常用排序算法总结 概述 在计算机科学中,排序算法是一种重要的操作。合理的排序算法能够大幅度提高计算机处理数据的性能...

网友评论

      本文标题:计算机经典算法——锦标赛排序算法

      本文链接:https://www.haomeiwen.com/subject/bxkeectx.html