码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 归并排序-Python


    归并排序的时间复杂度O(nlogn),空间复杂度为O(n)

    首先我们先假设有两个有序数组,我们去进行一次归并

     

    用代码实现

    ?
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    def merge(li: list, start: int, mid: int, end: int) :
        res=[]
        j = mid +1
        while start <= mid and j <= end:
            if li[start] < li[j]:
                res.append(li[start])
                start +=1
            else:
                res.append(li[j])
                j +=1
        #运行到这一步,说明左右两边一定有一遍已经下标已经超了,即一定有一遍数字已经没了
        #然后判断如果是左边还有数字就把左边剩下的数字全部插入列表中,无需在做判断
        #判断如果是右边还有数字就把左边剩下的数字全部插入列表中,无需在做判断
        while start <= mid:
            res.append(li[start])
            start +=1
        while j <= end:
            res.append(li[j])
            j +=1
        li[start:end+1] = res
        return res

     最后交给递归

  • 相关阅读:
    无心剑七绝《七夕牵手》
    JDBC编程
    小满nestjs(第八章 nestjs 控制器)
    PyQt5快速开发与实战 7.2 信号与槽再细分 && 7.3 信号与槽的高级玩法
    高度“智慧”护航先进技术,王力重新定义“智慧门”
    cesium态势标会(距离测量 ---- 不可修改)
    【C++ 面试 - 新特性】每日 3 题(十)
    SpringBoot整合MyBatis-Plus
    微信小程序:BLE蓝牙开发
    uniapp的动态表单实现
  • 原文地址:https://www.cnblogs.com/yetangjian/p/16439834.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号