博客
关于我
python 实现归并排序
阅读量:249 次
发布时间:2019-03-01

本文共 1025 字,大约阅读时间需要 3 分钟。

归并排序–分而治之

思想:分而治之,数组从中间划分,一分为二,递归的解决左右子集

核心:合并有序的数组
时间复杂度 o ( n l o g n ) o(nlogn) o(nlogn),以2为底
时间复杂度分析:长度为n的数组,二分需要 l o g ( n ) 次 log(n)次 log(n)
合并有序数组,需进行规模为n的操作,所以需要 n ∗ l o g n n*logn nlogn规模的运算

缺点:需要额外的辅助空间 O ( n ) O(n) O(n)

要求:十五分钟以内写出归并排序

#python 实现归并排序#分而治之的思想 时间复杂度 O(nlogn)def merge_sort(li):    # 作用 将传递进来的列表拆分到最小单元(函数的出口)    if len(li) == 1:        return li    mid = len(li) // 2    left = li[:mid]    right = li[mid:]    left_li = merge_sort(left)  # 判断 left列表是否为最小单元    right_li = merge_sort(right)    # 判断 right列表是否为最小单元    return marge(left_li, right_li)  # 合并    # print(left_li,right_li)                                           def marge(left_li, right_li):    reslut = []    while len(left_li) > 0 and len(right_li) > 0:        if left_li[0] > right_li[0]:            reslut.append(right_li.pop(0))        else:            reslut.append(left_li.pop(0))    if left_li:        reslut.extend(left_li)    if right_li:        reslut.extend(right_li)    return resluts = merge_sort([1,5,3,2,6,8,4])print(s)

转载地址:http://xpcv.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0021---NIO编写,快速入门---编写服务器
查看>>
Netty工作笔记0022---NIO快速入门--编写客户端
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0026---NIO 网络编程应用--群聊系统1---编写服务器1
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
查看>>
Netty工作笔记0029---NIO 网络编程应用--群聊系统4--客户端编写2
查看>>
Netty工作笔记0030---NIO与零拷贝原理剖析
查看>>
Netty工作笔记0031---NIO零拷贝应用案例
查看>>
Netty工作笔记0032---零拷贝AIO内容梳理
查看>>
Netty工作笔记0033---Netty概述
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0035---Reactor模式图剖析
查看>>
Netty工作笔记0036---单Reactor单线程模式
查看>>
Netty工作笔记0037---主从Reactor多线程
查看>>
Netty工作笔记0038---Netty模型--通俗版
查看>>
Netty工作笔记0039---Netty模型--详细版
查看>>
Netty工作笔记0040---Netty入门--服务端1
查看>>