Python算法设计与分析从入门到精通
上QQ阅读APP看书,第一时间看更新

4.4 合并排序算法

合并排序法是针对已经排好序的两个或两个以上的数列,通过合并的方式,将其组合成一个有序的大数列。使用合并排序法为一个数列排序时,首先将无序的数列分成若干小份,分若干份的规则就是不断把每段长度除以2(对半分),直到分到不能再分为止(当数列中最多只有两个元素时视为不可再分),然后对最小份进行排序,最后再逐步合并成一个有序的大数列,如图4.25所示。

图4.25 合并排序法工作原理

例如,有这样一组数据:33, 10, 49, 78, 57, 96, 66, 21,如图4.26所示。对其递增排序,步骤如下。

图4.26 无序的原始值

(1)将原始数列一分为二,得到两个数列,即数列1和数列2,数列1为33, 10, 49, 78;数列2为57, 96, 66, 21,如图4.27所示。

图4.27 将数列分为两个数列

(2)将数列1和数列2再一分为二,得到数列a、数列b、数列c和数列d,即每个数列中包含两个数据,并将每份中的两个数据进行排序,如图4.28所示。

图4.28 将4个数列中的数据分别排序

(3)合并排好序的数列元素。将数列a与数列b合并为数列A,数列c与数列d合并为数列B,再对数列A和数列B中的元素分别进行排序,如图4.29所示。

图4.29 将数列合并为两个数列并排序

(4)将数列A与数列B合并为一个数列,并对其中的元素排序,最终排序结果如图4.30所示。

图4.30 将数列合并为一个数列并排序

【实例4.7】 使用合并排序法将列表中的数字递增排序。(实例位置:资源包\Code\04\07)

用Python代码实现上方示例中的合并排序算法,具体代码如下:

运行结果如图4.31所示。

图4.31 合并排序法

【实例4.8】 争夺十二生肖。(实例位置:资源包\Code\04\08)

很久以前,玉帝决定在人间选拔12种动物作为生肖,他定好一个日子,动物们都来报名,先到的12种动物将成为十二生肖。利用合并排序法根据12种动物到达的时间(如数字6.25代表6:25到达),对十二生肖顺序进行排序。具体代码如下:

运行结果如图4.32所示。

图4.32 运行结果