博客
关于我
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/

你可能感兴趣的文章
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>