Return to Video

如何高效地整理书架? - Chand John

  • 0:07 - 0:09
    你是一名大学图书馆的管理员,
  • 0:09 - 0:11
    正在享受午后的闲暇时光。
  • 0:11 - 0:18
    这时快递突然送来了1280本各式各样的书。
  • 0:18 - 0:22
    这些书被排成长长的一排,
  • 0:22 - 0:23
    毫无规律,
  • 0:23 - 0:27
    自动分类系统又恰好出现了故障。
  • 0:27 - 0:30
    更糟糕的是,明天一早,
  • 0:30 - 0:32
    前来上课的学生们,
  • 0:32 - 0:37
    就会涌入图书馆借书。
  • 0:37 - 0:39
    如何才能在规定的时间内
    整理好所有书籍?
  • 0:39 - 0:45
    一种方法是
    从最前面的两本书开始。
  • 0:45 - 0:49
    如果这两本书位置正确
    则不做任何改动,
  • 0:49 - 0:51
    否则,将它们对换。
  • 0:51 - 0:53
    然后再看第二本书和第三本书,
  • 0:53 - 0:55
    重复这个操作,
  • 0:55 - 0:58
    直到你排列至最后一本书。
  • 0:58 - 1:01
    当你遇到应该位于末位的那本书,
  • 1:01 - 1:05
    那么只需要将它不断地与后一本书交换,
  • 1:05 - 1:09
    直至到达队伍末尾。
  • 1:09 - 1:12
    然后,再从头开始,
  • 1:12 - 1:16
    就可以找出倒数第二本书。
  • 1:16 - 1:19
    如此循环,直到将所有的书归位。
  • 1:19 - 1:22
    这个方法被称为 “冒泡排序”。
  • 1:22 - 1:24
    这个方法非常简单,但效率低下。
  • 1:24 - 1:29
    在第一次循环中,
    你需要进行1279次对比,
  • 1:29 - 1:34
    第二次循环则需要1278次,
  • 1:34 - 1:39
    总计818560次对比。
  • 1:39 - 1:44
    按每次比较需要1秒,
    这一过程将长达9天。
  • 1:44 - 1:49
    第二种方法是
    先将前两本排序。
  • 1:49 - 1:54
    然后,将第三本书和第二本进行排列。
  • 1:54 - 1:57
    如果第三本应位于第二本之前,则交换它们的位置。
  • 1:57 - 2:00
    再它和第一本书进行对比,
  • 2:00 - 2:02
    如果这本书应位于第一本之前,则交换它们的位置。
  • 2:02 - 2:04
    现在,你就完成了前三本的排列。
  • 2:04 - 2:08
    每次将一本书
    插入之前已经排列好的队伍中,
  • 2:08 - 2:12
    与前面相邻的一本书进行对比
    并判断是否交换,
  • 2:12 - 2:16
    直到这本书到达队伍中正确的位置。
  • 2:16 - 2:18
    这种方法被称为 “插入排序”。
  • 2:18 - 2:23
    与“冒泡排序”不同的是,
    这种方法通常不必比对所有相邻的书。
  • 2:23 - 2:27
    一般来说,
    每本书被对比的次数
  • 2:27 - 2:29
    只有前者的一半。
  • 2:29 - 2:32
    这样,总共的对比次数
  • 2:32 - 2:36
    也就是409280次。
  • 2:36 - 2:38
    需要将近5天的时间。
  • 2:38 - 2:41
    对比的次数还是太多。
  • 2:41 - 2:43
    还有一种更好的办法:
  • 2:43 - 2:45
    首先,随机抽出一本书,
  • 2:45 - 2:50
    称之为“分界点”,
    然后将每本书都与之进行对比。
  • 2:50 - 2:52
    然后,根据“分界点”,
  • 2:52 - 2:56
    把所有应放在它之前的书放在左边,
  • 2:56 - 2:59
    其他的放在右边。
  • 2:59 - 3:00
    这样你就已经节省了大量的时间,
  • 3:00 - 3:04
    因为你再也不必将左边的书,
  • 3:04 - 3:07
    与右边的任何书进行比较。
  • 3:07 - 3:10
    现在,只看左边的一部分。
  • 3:10 - 3:13
    你可以从中再随机抽出一本书,
  • 3:13 - 3:17
    然后以此为另一个“分界点”。
  • 3:17 - 3:20
    你可以像这样不断地进行分割,
    产生新的“分界点”,
  • 3:20 - 3:22
    直到得出许多的分支。
  • 3:22 - 3:28
    每一个分支都可以用其他的方法进行重排,
    比如 “插入排序”。
  • 3:28 - 3:33
    每次“分界点”循环
    所需要的对比次数大约是1280次。
  • 3:33 - 3:35
    如果你的“分界点”分布十分均匀,
  • 3:35 - 3:41
    那么把整列书分成128个分支,每个10本,
    大约只需要7次循环,
  • 3:41 - 3:44
    也就是8960秒。
  • 3:44 - 3:49
    将每个分支进行排序,
    每个约需22秒。
  • 3:49 - 3:52
    这个方法被称为 “快速排序”。
  • 3:52 - 3:55
    它能将所有的书
    在三个半小时之内排列整齐。
  • 3:55 - 3:56
    但是也有特例。
  • 3:56 - 4:00
    取出的分界点可能全都挤在一端,
    这样你不会节省任何时间。
  • 4:00 - 4:01
    幸运的是,这种情况几乎不可能发生。
  • 4:01 - 4:05
    这也使得“快速排序”
  • 4:05 - 4:07
    成为编程中最高效的排序方法之一。
  • 4:07 - 4:11
    例如,它被用于网络购物中的价格排序,
  • 4:11 - 4:15
    或是按照距离
  • 4:15 - 4:16
    依次列举出最近的加油站地址。
  • 4:16 - 4:20
    在给书排序的例子中,
    “快速排序”为你节省了大量的时间。
  • 4:20 - 4:23
    多么充满乐趣的一天。
Title:
如何高效地整理书架? - Chand John
Speaker:
Chand John
Description:

原视频: http://ed.ted.com/lessons/what-s-the-fastest-way-to-alphabetize-your-bookshelf-chand-john

想像你在一座大学图书馆里工作。你正在享受下午的闲暇时光,这时快递突然送来了1280本各式各样的书。这些书被无序地排成一行,而自动排序系统又出现了故障。那么,你怎样才能在最短的时间内排列好所有的书籍? Chand John向我们阐述了如何利用特定的算法帮助图书管理员和搜索引擎快速整理资料。

演讲者 Chand John,动画制作 Anton Trofimov。

more » « less
Video Language:
English
Team:
closed TED
Project:
TED-Ed
Duration:
04:39

Chinese, Simplified subtitles

Revisions