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

你可能感兴趣的文章
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>