03_2排序算法:快速排序、归并排序

news2025/1/22 21:57:14

 开始系统学习算法啦!为后面力扣和蓝桥杯的刷题做准备!这个专栏将记录自己学习算法是的笔记,包括概念算法运行过程,以及代码实现,希望能给大家带来帮助,感兴趣的小伙伴欢迎评论区留言或者私信博主哦!今天更新的是《03_2排序算法:快速排序、归并排序》

目录

快速排序概念

        算法步骤

        时间复杂度

        算法实现

        总结

归并排序概念

        算法步骤

        时间复杂度

        程序实现

        总结


快速排序概念

快速排序(Quicksort),又称为交换排序,通过一趟排序将要排序的数据分割为独立的两部分。假设要排序的列表是A[0]...A[N-1],首先任意选取一个数据(通常选用列表的第一个数)作为基准数据,一般我们都选择第一个数作为基准数据,然后将所有比它小的数都放到它的左边,所有比它大的数都放到它的右边,这个过程称为快速排序。值得注意的是,快速排序不是一种稳定的排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变化。

算法步骤

  1. 设置两个low、high,排序开始的时候:low=0,high=N-1
  2. 以第一个列表元素作为基准数据,赋值给mid,即mid=A[0]
  3. 从high开始向前搜索,即由后开始向前搜索(high--),找到第一个小于mid的值A[high],将A[high]和A[low]的值交换
  4. 从low开始向后搜索,即向前开始向后搜索(low++),找到大于mid的A[low],将A[low]和A[high]的值交换。
  5. 重复第3、4步,直到low=high;

时间复杂度

  • 最优时间复杂度:O(nlogn) #每次分成两半,要分logn次,再乘遍历的n次
  • 最坏时间复杂度:O(n2) #每次只分出一个元素出来,要分n次,再乘遍历的n次
  • 稳定性:不稳定

算法实现

def quick_sort(alist,start,end):
    """
    :param alist:
    :return:alist.sort
    快速排序首先要选择一个基准,将其他数据与这个基准比较,比它大的放右边,比它小的放左边,循环这个过程,完成排序
    定义两个指针,一个low一个high,
    开始是high先做比较,如果high对应的元素比基准大就不懂,high--,如果比基准小,则与low对应的元素交换,然后low++
    直到low==high说明一趟快速排序已经完成,再将基准添加到序列中
    上面已经完成一次快速排序,再将左序列和右序列进行递归,注意设置一个出口,即可完成整个遍历
    以alist = [5,1,3,2,8,7,6,4]为例
    以alist = [4,1,3,2,8,7,6,4]为例
    """
    # 递归的出口
    if start >= end:
        return
    mid = alist[start]  # 定义基准 5
    low = start  # 左指针
    high = end  # 右指针 7
    # 判断high是不是大于mid,大于的话就不用交换,之间high--,直到小于的时候进行交换
    while low <high:
        while alist[high] >= mid and high > low:  #7>0
            high -=1
        alist[low] = alist[high]
        #判断low是不是小于mid, 小于的话就不用交换,之间low++,直到大于的时候进行交换
        while alist[low] < mid and high>low:
            low += 1
        alist[high] = alist[low]
    alist[low] = mid
    quick_sort(alist,0,low-1)
    quick_sort(alist,low+1,end)
    return alist

总结

主要是两个指针的交替变化,可以用while循环来执行,判断high是不是大于mid,大于的话就不用交换,之间high--,直到小于的时候进行交换;判断low是不是小于mid, 小于的话就不用交换,之间low++,直到大于的时候进行交换;最后再加上基准,这样就完成一次快速排序,之后再从外面用一个while循环,里面用递归思想不断对左序列和右序列进行操作,记得写一个出口,start >= end,这样快速排序算法就结束了。


归并排序概念

归并排序(Merge sort)是采用分治法的一个非常典型的应用。归并排序的思想就是先递归分解数组,再合并数组。将数组分解最小之后,然后合并两个有序数组,基本思想是比较两个数组的最前面的数,谁小就先取谁,取了后相应的指针就向后移一位。然后再比较,直至一个数组为空,最后把另一个数组的剩余部分复制过来即可。

算法步骤

先分再合

时间复杂度

  • 最优时间复杂度:O(nlogn)
  • 最坏时间复杂度:O(nlogn)
  • 稳定性:稳定

程序实现

def Merge_sort(alist):
    """
    主要思想就是分治法,先拆分再合并
    整个框架是递归算法,既包括拆解成一个一个的列表,也包列表的缝合
    以为[5,1,3,2,8,7,6,4]例,拆解成[5],[1],[3],[2],[8],[7],[6],[4]
    第一次合并成[1,5],[2,3],[7,8],[4,6]
    第二次合并成[1,2,3,5],[4,6,7,8]
    第三次合并成[1,2,3,4,5,6,7,8]
    :param alist:
    :return: alist.sort
    """
    n = len(alist)
    mid = n //2
    if n <= 1:
        return alist
    left_list = Merge_sort(alist[0:mid])
    right_list = Merge_sort(alist[mid::])
    left_p = 0 # 定义左指针
    right_p = 0 # 定义右指针
    result_list =[]
    while left_p < len(left_list) and right_p < len(right_list):
        if left_list[left_p] < right_list[right_p]:
            result_list.append(left_list[left_p])
            left_p += 1
        else:
            result_list.append(right_list[right_p])
            right_p += 1
    result_list.extend(left_list[left_p::])
    result_list.extend(right_list[right_p::])

    return result_list

总结

主要思想就是分治法,先拆分再合并,整个框架是递归算法,既包括拆解成一个一个的列表,也包列表的缝合。定义两个指针,一个左指针,一个右指针,先比较两个指针指向的的元素大小,将小的元素添加到目标序列中,然后该指针+1继续比较,直到某一个指针走到头,此时将另一个指针指向元素的后面元素全部添加到目标序列中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/91672.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IIS2MDCTR传感器规格、ISM303DACTR磁力计应用、STPSC20H12WL二极管特点

IIS2MDC 3轴数字式磁性传感器具有高达50高斯的磁场动态范围以及16位数据输出。IIS2MDC设有I2C串行总线接口&#xff0c;可支持标准模式 (100kHz)、快速模式 (400kHz)、快速模式 (1MHz) 以及高速模式 (3.4MHz)。 该传感器还设有SPI串行标准接口&#xff0c;另外对其进行配置后可…

IBPS低代码产品公司流辰信息:用心研发,不负众望!

作为一家低代码产品公司&#xff0c;流辰信息一直以高标准严格要求自己&#xff0c;努力研发&#xff0c;努力提升服务品质&#xff0c;从专业的角度为中大型企业数字化转型积极赋能&#xff0c;共创价值。 IBPS低代码开发产品是流辰信息努力研发的硕果&#xff0c;是满足企业级…

教材推荐网站

开发工具(eclipse/idea/vscode等)&#xff1a; 数据库(sqlite/mysql/sqlserver等)&#xff1a; 功能模块(请用文字描述&#xff0c;至少200字)&#xff1a; 高校教材推介交流平台的开发主要功能教师发布课程名称、用书信息&#xff0c;各出版社推荐样 书&#xff08;线上&#…

CRTO 考试总结

写在最前&#xff1a;欢迎大家来我的 Discord 频道 Northern Bay。邀请链接在这里&#xff1a;https://discord.gg/9XvvuFq9Wb 一起进步&#xff0c;一起 NB~ 背景 今天我结束了 Zero Point Security RTO I 的考试。证书到手。 Zero Point Security 是一家 Base 在英国的安全…

知乎zse-96算法-js补环境方案

文章目录 1. js代码定位与抠取2. 初步分析 开始补环境3. 完整的补全环境的js整合4. 编写python代码调用测试1. js代码定位与抠取 抠js和上篇jsrpc方案一样,传送门:知乎zse-96算法-jsrpc方案 这里简单提一下 直接进入encrypt方法里, 往上先把整个方法体给扣下来: "u…

c语言教工工资管理系统课程设计

序 言 借助现代信息技术和管理理论&#xff0c;建立学校管理信息系统势在必行。对学校而言&#xff0c;全面开发和应用计算机管理信息系统就是有必要的。在学校管理中&#xff0c;教师是学校的宝贵资源&#xff0c;也是学校的“生命线”&#xff0c;因此人事管理是学校的计算机…

JAVA中生成随机数Random VS ThreadLocalRandom性能比较

前言 大家项目中如果有生成随机数的需求&#xff0c;我想大多都会选择使用Random来实现&#xff0c;它内部使用了CAS来实现。 实际上&#xff0c;JDK1.7之后&#xff0c;提供了另外一个生成随机数的类ThreadLocalRandom&#xff0c;那么他们二者之间的性能是怎么样的呢&#x…

用JavaScript写代码将硬盘序列号从16进制字符串转换为ASCII字符串,兼谈EditPlus和Edge浏览器对JavaScript脚本支持的一点差别

之前写的系统信息收集报告程序SysInfo的一个功能就是收集并报告系统中的硬盘序列号。在之前的测试中这项功能表现不错&#xff0c;但前两天用SysInfo收集一台电脑的信息时&#xff0c;显示的硬盘序列号与其它硬盘序列号读取程序显示的顺序不一样。于是着手对SysInfo的相关代码进…

网络爬虫爬取数据并制作词云全过程【内附可执行代码注释完整】

文章目录前言网络爬取数据部分小知识点利用正则表达式在字符串中提取到url&#xff08;https以及http&#xff09;仅仅只保存字符串中的中文字符爬取数据生成词云jieba分词生成词云生成词云最终版代码总结前言 快期末了&#xff0c;有个数据挖掘的大作业需要用到python的相关知…

Json字符串转成对象

Json字符串转成对象 Hello吖&#x1f60a;&#xff0c;我是孤音&#xff08;一个你理解不了的程序猿&#xff09;&#xff0c;今天来分享一个小技巧&#xff0c;能够大大滴提高效率额 问题&#x1f635; 接收到一串JSON格式的字符串&#xff0c;需要获取其中某些字段的值 思路…

一天梳理完React所有面试考察知识点

性能优化 性能优化&#xff0c;永远是面试的重点&#xff0c;性能优化对于 React 更加重要 在页面中使用了setTimout()、addEventListener()等&#xff0c;要及时在componentWillUnmount()中销毁使用异步组件使用 React-loadable 动态加载组件shouldComponentUpdate(简称SCU …

更高效、更精确的预测性维护方案是如何实现的?

一、预测性维护的必要性 设备维护一般有三种模式&#xff1a;事后维护、预防性维护和预测性维护。事后维护通常是在设备产生故障后采取措施进行维护&#xff0c;是一种成本较大的维护方式。预防性维护属于事先维护&#xff0c;是一种基于时间、性能等条件&#xff0c;对设备进…

A_A05_003 STC-ISP串口调试助手使用

目录 一、软件获取 二、软件基本功能介绍 1、接收缓冲区 2、串口通信参数配置区串口打开关闭其他设置区域 3、发送缓冲区 4、多字符发送区 三、注意事项 一、软件获取 网盘链接 直戳跳转 二、软件基本功能介绍 1、接收缓冲区 注&#xff1a;先选中串口助手切换到上图界…

OneNav Extend网址导航书签系统源码魔改版

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍 OneNav Extend 是一款功能强大的书签&#xff08;导航&#xff09;管理程序&#xff0c;使用PHP SQLite 3开发&#xff0c;界面简洁&#xff0c;安装简单&#xff0c;使用方便。 OneNa…

通达信下单接口如何执行量化策略?

在量化市场上&#xff0c;有很多交易系统就是通过执行量化策略来进行盈利&#xff0c;比如像通达信下单接口系统&#xff0c;其中就包括开仓、买入、止盈、止损方法与策略执行主函数等&#xff0c;那么执行这些策略呢&#xff1f; 想要了解清楚这个问题也很简单&#xff0c;通…

ssm+Vue计算机毕业设计校园疫情信息管理系统(程序+LW文档)

ssmVue计算机毕业设计校园疫情信息管理系统&#xff08;程序LW文档&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项…

linux下gcc编程12-window下clion编译调试redis7.0

redis介绍 Redis 通常被称为数据结构服务器。这意味着 Redis 通过一组命令提供对可变数据结构的访问&#xff0c;这些命令使用具有 TCP 套接字和简单协议的服务器-客户机模型发送。因此&#xff0c;不同的进程可以以共享的方式查询和修改相同的数据结构。 在 Redis 中实现的数…

WebDAV之葫芦儿·派盘 + Enpass

Enpass 支持WebDAV方式连接葫芦儿派盘。 想找一款加密软件把原来本地存储的明文密码,经过加密后存储到自己的电脑上。同时要具备云同步功能,有些安全级别没那么高的内容,可以同步到各端,以供快速查看、编辑。那您选择Enpass准没错了,还可以同步备份到个人私有派盘,跨平…

【vue】插槽,Provided/inject和vue3生命周期

&#xff08;1&#xff09;第一部分&#xff0c;关于插槽 插槽的作用是再子组件模板里面预留出位置&#xff0c;可以插入父组件的东西例如 <template> 下面是插槽展示的内容和&#xff1a;<slot/> </template>//父组件调用子组件布局的时候 <content>…

电竞蓝牙耳机什么牌子好?2022游戏蓝牙耳机推荐

随着玩游戏的人越来越多&#xff0c;随之而来的是越来越多的电竞蓝牙耳机的出现。在游戏中能够精准获取人物周围的声音变化&#xff0c;音效的同步汇入&#xff0c;这是喜欢戴蓝牙耳机玩游戏的用户所追求的听声辨位。那么&#xff0c;在众多的电竞蓝牙耳机当中&#xff0c;什么…