博客
关于我
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中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>