9. Lower Bound on Comparison-based Sorting

通过见减少对比的次数,我们可以提高算法的效率。

We can use a binary comparison tree to represent the sort procedure, where

  1. each node in the tree represents one comparison
  2. each node is labelled by the indices of the pair comparison elements
示意图

Important observations on the binary comparison tree of sorting:

  1. The number of nodes from the tree root to a tree leaf corresponds to the number of comparisons to sort a sequence
  2. There are n! tree leaves in the binary comparison tree, as there are
    n! = n·(n−1)·(n−2)·...·2·1 different sorted sequences for n elements to be sorted, depending on the n input element sequence.
  3. Minimizing the number of comparisons of sorting n elements is equivalent to minimizing the depth (or the height) of the binary comparison tree.

In other words, the problem becomes to construct a binary comparison tree that has n! leaves such that the longest path from the tree root to a tree leaf is minimized.(设计算法一般考虑最坏情况)

我们发现:
The depth of any binary tree containing no less than 2^h leaves is at least h − 1, assuming that the depth of the tree root is 1.

Thus, if a binary comparison tree contains N = n! leaves, then its minimum depth h is ⌈logN⌉,due to the fact that n!≥2^h andN=n!.

我们用二叉树可以证明,对比的最佳时间复杂度是nlogn。那么,optimal == 解决问题需要时间的下限 = 算法需要时间上限,该算法就可以当做最佳。

Question

(a) In the following definitions on the optimal algorithm for a problem P, which de- scription(s) is (are) correct, assuming that the problem size is n and its lower bound is n(n log log n)?

  1. Its running time is linear with the problem size n
  2. The lower bound of its running time is w(n log n)
  3. The lower bound of its running time is n(n log2 n)
  4. The upper bound of its running time is O(n2 log log n)

(b) In the following comparison-based sorting algorithms, (1) which ones are optimal algorithms and which ones are not?
• quick sort • heap sort • shell sort • bubble sort • merge sort • insertion sort

Answer: Heap and merge sort are optimal.

In the linear-time selection algorithm, the n elements in the input sequence are divided into groups of size 5 except the last group. Does the algorithm still run in time O(n) if the input elements are divided into groups of size 27 instead? Formulate the time complexity of the algorithm as a recurrence and solve the recurrence.


Assume that there is a comparison operator with a switch on it. The comparison operator can can take upto 3 elements as its input, its output is either the minimum value or the maximum value of the 3 elements, depending on the switch setting (e.g., setting the switch on, its output is the minimum value, otherwise (setting its switch off) its output is the minimum value).
If we count each comparison operator with its switch setting as one comparison. Given n >= 6 elements and assume that n is divisible by 6, what is the minimum number of comparisons needed in order to find the maximum and minimum values from these n elements? Can you propose an algorithm for it? Show the number of comparisons by your algorithm.


(b) Insert the keys 7,6,2,13,4,6,5,12 into a min-heap once a time, then remove the key in the root repeatedly until the heap is empty. Use diagrams to illustrate each step of the insertion and deletion procedure. What is the time complexity of sorting in this fashion?

Insertion
Extraction
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • **2014真题Directions:Read the following text. Choose the be...
    又是夜半惊坐起阅读 9,460评论 0 23
  • 认识你之后,我才明白,这个世界上有些东西,不是你努力了就能拥有的。你总是说我很好,可惜,我还没有好到让你想要拥有。...
    安夏茉阅读 822评论 120 27
  • 从未都坐在自己最舒适的椅子忘记了,站身给别人也坐一会儿。 年轻的真相是一心想追求自己远大的理想,但与此同时也忽略了...
    旦真陈里阅读 139评论 0 0
  • 这个世界在残酷惩罚不改变的人 文by琉璃树 这个标题是最近刷屏了深圳地铁的广告语,同一...
    琉璃树I浅浅兮阅读 10,131评论 54 74
  • 十年树木 百年树人 九十岁的他 还在作梦 问他梦是什么? 等得黄花菜都凉了 他还做着他的黄花梦 人生不满百...
    淘猴侯孙行阅读 174评论 3 7