Python 实现把两个排好序的的列表合并成一个排序列表

Posted 潇湘旧友

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 实现把两个排好序的的列表合并成一个排序列表相关的知识,希望对你有一定的参考价值。

列表是生序的

# -*- coding: utf-8 -*-

# 合并两个排序的数组


def merge_list(a, b):
    if not a:
        return b
    if not b:
        return a
    a_index = b_index = 0
    ret = []
    while a_index < len(a) and b_index < len(b):
        if a[a_index] <= b[b_index]:
            ret.append(a[a_index])
            a_index += 1
        else:
            ret.append(b[b_index])
            b_index += 1
    if a_index < len(a):
        ret.extend(a[a_index:])
    if b_index < len(b):
        ret.extend(b[b_index:])
    return ret


if __name__ == ‘__main__‘:
    a = [1, 2, 3, 5, 7, 9]
    b = [1, 2, 2, 4, 5, 6, 8, 10]
    print merge_list(a, b)

以上是关于Python 实现把两个排好序的的列表合并成一个排序列表的主要内容,如果未能解决你的问题,请参考以下文章

归并排序的细节讲解与复杂度分析

归并排序

Java 对已经排好序的数组进行分组。

合并排序

递归与分治-合并排序快速排序以及循环赛问题

合并两个已经排好序的不等长的数组