冒泡排序、选择排序、插入排序

news2024/12/26 9:19:29

冒泡排序

思路:

  1. 每次循环比较相邻两个元素,如果左边元素>右边元素,则交换位置。结果:将最大值放到最右边;
  2. 一次循环过后,左边无序区域减少一个数,右边有序取增加一个数;
  3. 序列长度为n,一共循环(n-1)次,并且 i 次循环需要比较(n-1-i)次。

评价:
时间复杂度
最坏情况: O ( n 2 ) O(n^2) O(n2)
平均情况:​​ O ( n 2 ) O(n^2) O(n2)
最好情况: O ( n 2 ) O(n^2) O(n2)

空间复杂度
所有情况: O ( 1 ) O(1) O(1)

稳定性:稳定。排序过程都是相邻的两位交换。

一次循环:
在这里插入图片描述
代码:

def bubble_sort(lst):
    """
    升序:每次循环把最大的数放到最右边
    优化:如果其中有一次循环没有发生任何交换,则提前结束
    """
    n = len(lst)
    # 外层循环控制比较的轮数
    for i in range(n - 1):
        exchange = False
        # 内层循环执行相邻元素的比较和交换
        for j in range(n - 1 - i):
            if lst[j] > lst[j + 1]:
                # 如果前面的元素大于后面的元素,进行交换
                lst[j], lst[j + 1] = lst[j + 1], lst[j]
                exchange = True
        print(lst)  # 打印每次循环的结果
        if not exchange:
            return

# 测试代码
numbers = [5, 8, 9, 1, 3]
print("最开始的数组为:\n", numbers)
bubble_sort(numbers)
print("经过排序后的数组为:\n", numbers)

选择排序

思路:

  1. 每次循选择最小值放到最左边;
  2. 一次循环过后,右边无序区域减少一个数,左边有序取增加一个数;
  3. 序列长度为n,一共循环(n-1)次,每次从(i+1,n)中选择最小值。

评价:
时间复杂度
最坏情况: O ( n 2 ) O(n^2) O(n2)
平均情况:​​ O ( n 2 ) O(n^2) O(n2)
最好情况: O ( n 2 ) O(n^2) O(n2)

空间复杂度
所有情况: O ( 1 ) O(1) O(1)

稳定性:不稳定。排序过程不是相邻的两位交换。

代码:

def selection_sort(lst):
    """思路:每次循环找出最小值,并放到无序区的最左边"""
    n = len(lst)
    for i in range(n - 1):
        min_index = i
        for j in range(i + 1, n):
            if lst[j] < lst[min_index]:
                min_index = j
        lst[i], lst[min_index] = lst[min_index], lst[i]

# 测试代码
numbers = [5, 2, 9, 1, 3]
selection_sort(numbers)
print(numbers)

插入排序

思路:

  1. 类似于玩牌,初始时手里只有一张牌(将最左边第一个元素看作有序区);
  2. 每次从右边无序区拿第一个元素,放到有序区(循环与有序区右边比较,有序区元素大则往后移动);
  3. 序列长度为n,循环摸牌(1,n)位置的无序牌。

评价:
时间复杂度
最坏情况: O ( n 2 ) O(n^2) O(n2)
平均情况:​​ O ( n 2 ) O(n^2) O(n2)
最好情况: O ( n 2 ) O(n^2) O(n2)

空间复杂度
所有情况: O ( 1 ) O(1) O(1)

稳定性:稳定。排序过程没有不相邻的元素对位交换。

循环前:
在这里插入图片描述

循环过程中:
在这里插入图片描述

代码:

def insertion_sort(lst):
    for i in range(1, len(lst)):
        key = lst[i]  # 摸牌
        j = i - 1  # j是有序区最大的牌的index
        # 如果有序区的牌比摸到的牌大,往后移动一位
        while j >= 0 and lst[j] > key:
            lst[j + 1] = lst[j]
            j -= 1
        # 循环结束找到了摸到牌正确的插入位置
        lst[j + 1] = key


# 测试代码
numbers = [5, 2, 9, 1, 3]
insertion_sort(numbers)
print(numbers)

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

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

相关文章

【C++】AVL树的插入实现

目录 AVL树的概念AVL树节点的定义AVL树的插入AVL树的旋转左单旋(parent->_bf 2 && cur->_bf 1)a,b,c当高度为0a,b,c当高度为1a,b,c当高度为2a,b,c当高度为...... 右单旋(parent->_bf -2 && cur->_bf -1)a,b,c当高度为0a,b,c当高度为1a,b,c当高…

【群智能算法】基于浣熊优化算法的工程应用问题优化【Matlab代码#43】

文章目录 【可更换其他算法&#xff0c;获取资源请见文章第5节&#xff1a;资源获取】1. 原始COA算法1.1 开发阶段1.2 探索阶段 2. 工程应用问题优化2.1 压力容器设计2.2 拉压弹簧设计 3. 部分代码展示4. 仿真结果展示5. 资源获取 【可更换其他算法&#xff0c;获取资源请见文章…

Spring事件机制让你的代码更优雅

今天为大家分享一下Spring的事件机制的使用&#xff0c;它是spring中一个非常好用也很实用的机制。 1. spring事件机制的概念 Spring的事件机制是基于观察者模式实现的&#xff0c;它可以在我们的实际应用程序中实现代码之间的解耦&#xff0c;提高代码的可维护性和可扩展性。…

ShardingSphere-Proxy 分库分表

安装ShardingSphere-Proxy 中间件封装 定位为透明化的数据库代理端&#xff0c;提供封装了数据库二进制协议的服务端版本&#xff0c;用于完成对异构语言的支持。 目前提供 MySQL 和 PostgreSQL版本&#xff0c;它可以使用任何兼容 MySQL/PostgreSQL 协议的访问客户端&#x…

面试必问:四种经典限流算法

今天给大家分享一下限流方面的&#xff0c;大家都知道&#xff0c;在分布式系统中&#xff0c;高并发场景下&#xff0c;为了防止系统因突然的流量激增而导致的崩溃&#xff0c;同时保证服务的高可用性和稳定性&#xff0c;限流是最常用的手段。希望能够给大家带来帮助&#xf…

STM32常见面试题

一、STM32F1和F4的区别&#xff1f; 内核不同&#xff1a;F1是Cortex-M3内核&#xff0c;F4是Cortex-M4内核&#xff1b; 主频不同&#xff1a;F1主频72MHz&#xff0c;F4主频168MHz&#xff1b; 浮点运算&#xff1a;F1无浮点运算单位&#xff0c;F4有&#xff1b; 功能性能&…

【无标题】vue中表单绑定v-model

表单绑定v-model 表单控件在实际开发中是非常常见的。特别是对于用户信息的提交&#xff0c;需要大量的表单。 Vue中使用v-model指令来实现表单元素和数据的双向绑定。 案例的解析&#xff1a; 当我们在输入框输入内容时 因为input中的v-model绑定了message&#xff0c;所以会…

Vue-搭建Vuex开发环境

1 安装Vuex 安装之前需要了解一个版本问题&#xff0c;在vue2中&#xff0c;要用vuex的3版本&#xff0c;在vue3中&#xff0c;要用vuex的4版本&#xff0c;要严格遵循这个版本要求&#xff0c;不然就会出现各种意想不到的问题&#xff0c;例如下方安装报错&#xff0c;就算因…

ubuntu修改应用图表|任务栏收藏|快捷方式|收藏夹

需要知道应用程序对应的.desktop文件的位置&#xff0c;然后使用sudo gedit打开。修改对应位置的信息就可以了。 参考&#xff1a;Linux下Desktop文件入门 1.desktop文件位置 一般存放在/usr/share/applications这个位置里面。 以vscode为例&#xff0c;使用sudo gedit code…

POJ - 2287 Tian Ji -- The Horse Racing

题目来源 2287 -- Tian Ji -- The Horse Racing (poj.org) 题目描述 田忌赛马是中国历史上一个著名的故事。 这个故事发生在2300年前&#xff0c;田忌是齐国的一个大官&#xff0c;他喜欢和齐王以及其他公子赛马。 田忌和齐王都有三类马&#xff0c;分别是下等马&#xff0…

1750_使用gcc对嵌入式代码控制逻辑进行测试

全部学习汇总&#xff1a; GreyZhang/c_basic: little bits of c. (github.com) 相信很多人的C语言学习是从printf开始的&#xff0c;为了验证我们的程序代码运行结果&#xff0c;我们通常会选择使用printf打印出我们计算的结果看一下是否与预期一致。到了嵌入式软件开发&#…

web前端工程师个人简历编写(附详细代码)

web前端工程师 h5css3完成简历编写&#xff0c;效果如下&#xff1a; 底部附有详细代码编写 编写Web前端工程师个人简历时&#xff0c;需要注意以下几点&#xff1a; 简洁明了&#xff1a;简历应该简洁明了&#xff0c;内容要点突出&#xff0c;避免冗长和废话。用简洁的语言…

Boost的介绍、安装与环境配置

文章目录 一、Boost库简介二、Boost的安装与编译&#xff08;一&#xff09;下载解压&#xff08;二&#xff09;编译静态库 三、配置VS环境四、其它环境的配置&#xff08;vscode、DevC&#xff09;&#xff08;一&#xff09;在DEVC中配置使用boost库的环境&#xff08;二&am…

java: 程序包javax.servlet.http不存在

问题描述 当项目从2.7.x的springboot升级到3.0.x的时候&#xff0c;遇到一个问题“java: 程序包javax.servlet.http不存在” 。这可能是一些包的精简变化导致的。错误信息如下&#xff1a; 错误代码段 package com.softdev.system.generator.config;import com.softdev.system…

深度学习-ubuntu18.04+RTX3080+cuda11.2+cudnn8.1.0下安装polarstream全纪录

&#xff11;、安装 创建一个python3.7的虚拟环境 conda create --name polarstream python3.7 激活虚拟环境 source activate polarstream以下操作均在虚拟环境中进行 安装与cuda和python版本对应的torch版本,参考https://blog.csdn.net/didadifish/article/details/12748…

【软件设计师暴击考点】操作系统知识高频考点暴击系列【二】

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;软件…

栈的应用——括号匹配、表达式求值、递归

目录 一、栈在括号匹配中的应用逻辑实现代码实现 二、栈在表达式求值中的应用手算实现代码实现 三、栈在递归中的应用逻辑实现代码实现 一、栈在括号匹配中的应用 括号匹配&#xff0c;顾名思义。若括号按照正确的格式嵌套&#xff0c;则可正确匹配&#xff0c;例如([])&#…

scratch lenet(12): LeNet-5输出层和损失函数的计算

文章目录 1. 目的2. 输出层结构2.1 Gaussian Connection2.2 Gaussian Connection 的 weight 可视化 3. Loss Function3.1 当前类别判断错误时&#xff0c;loss function 中的项&#xff08;基本项&#xff09;3.2 判断为其他类别时&#xff0c; loss function 中的项&#xff0…

Spring发展历程及其体系结构

⭐作者介绍&#xff1a;大二本科网络工程专业在读&#xff0c;持续学习Java&#xff0c;努力输出优质文章 ⭐作者主页&#xff1a;逐梦苍穹 ⭐所属专栏&#xff1a;Spring 目录 发展历程体系结构 发展历程 体系结构 Spring框架的体系结构的主要组成部分&#xff1a; 核心容器…

idea如何集成Tomcat

&#xff08;1&#xff09;、这里应该找Add Configuration点击这里&#xff1a;如果没有标志&#xff0c;点击Exit (2)、这里可以配置一个配置项&#xff1a; &#xff08;3&#xff09;、loacl是本地&#xff0c;那个是远程&#xff1a;这里我选择本地 &#xff08;4&#xff…