当前位置: 首页 > news >正文

排序算法入门:冒泡、选择、插入排序详解

一、先解答上次的 思考题

图:顶点 0 1 2 3,边:0-1、0-2、1-2、2-3从 0 开始 BFS 典型顺序:0 1 2 3


二、今天学习目标

  1. 了解排序算法的分类与指标
  2. 掌握冒泡排序
  3. 掌握选择排序
  4. 掌握插入排序
  5. 完整可运行代码 + 复杂度总结

三、排序基础概念

  • 稳定排序:相等元素前后顺序不变
  • 时间复杂度:执行快慢
  • 空间复杂度:占用额外内存多少

今天这三个都是:

  • 简单直观
  • 时间复杂度O(n²)
  • 适合小规模数据

四、1. 冒泡排序(Bubble Sort)

思想:两两比较,大的往后 “冒”,每轮冒出一个最大值。

// 冒泡排序 void bubbleSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } }

五、2. 选择排序(Selection Sort)

思想:每轮选最小的,放到已排序区间末尾

// 选择排序 void selectionSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { int minIdx = i; for (int j = i + 1; j < n; j++) { if (arr[j] < arr[minIdx]) minIdx = j; } // 交换 int temp = arr[i]; arr[i] = arr[minIdx]; arr[minIdx] = temp; } }

六、3. 插入排序(Insertion Sort)

思想:像摸牌一样,把当前数插入前面已经排好的序列里

// 插入排序 void insertionSort(int arr[], int n) { for (int i = 1; i < n; i++) { int key = arr[i]; int j = i - 1; while (j >= 0 && arr[j] > key) { arr[j + 1] = arr[j]; j--; } arr[j + 1] = key; } }

七、完整测试代码

#include <stdio.h> // 三种排序函数放这里 …… // 打印数组 void printArr(int arr[], int n) { for (int i = 0; i < n; i++) printf("%d ", arr[i]); printf("\n"); } int main() { int arr1[] = {5, 2, 9, 1, 5, 6}; int n = sizeof(arr1) / sizeof(arr1[0]); printf("原数组:"); printArr(arr1, n); // 测试冒泡 bubbleSort(arr1, n); printf("冒泡排序后:"); printArr(arr1, n); return 0; }

运行结果

原数组:5 2 9 1 5 6 冒泡排序后:1 2 5 5 6 9

八、复杂度对比表

表格

排序最好最坏平均稳定原地
冒泡O(n)O(n²)O(n²)稳定
选择O(n²)O(n²)O(n²)不稳定
插入O(n)O(n²)O(n²)稳定

记忆口诀:

  • 冒泡:两两交换
  • 选择:选最小放前面
  • 插入:摸牌插位置

九、今日小练习

对数组{3, 1, 4, 2, 7, 5}分别用三种排序实现并输出结果。

http://www.jsqmd.com/news/652572/

相关文章:

  • 如何打造无网络环境下的iScroll开发参考方案:完整离线文档指南
  • Python 爬虫实战:精准抓取母婴电商平台数据,深入分析用户评价洞察市场趋势
  • 如何快速上手Remmina:面向新手的10个简单设置技巧
  • 如何优化Mantine Checkbox组件交互体验:从默认到高级的完整指南
  • Davinci代码是如何实现Autosar-CanTsyn模块功能的
  • 如何使用ONNX Simplifier优化模型:生产环境部署的完整指南
  • 别再手动调亮度了!用Python+OpenCV直方图均衡化,5分钟让模糊图片变清晰(附完整代码)
  • 探索ComfyUI-WanVideoWrapper:解密AI视频生成的核心架构与实战应用
  • 避坑指南:ESP32连接多个I2C传感器(OLED、BH1750)的常见问题与解决方法
  • TongWeb应用部署实战:从单机到集群的路径选择与避坑指南
  • 别让Simulink生成的代码拖慢你的嵌入式系统:手把手教你配置这7个关键优化选项
  • OV5640摄像头模组选型与二次开发避坑指南:DVP vs MIPI接口到底怎么选?
  • 从时序到中断:手把手教你用C51单片机定时器实现一个精准的1秒LED闪烁
  • 如何利用Bootstrap实现高效用户体验监控:从行为收集到数据分析的完整指南
  • 别再问工厂要什么文件了!用Altium Designer 19生成Gerber文件,这份保姆级教程一次讲透
  • 微信小程序下载PDF的‘隐藏’路径揭秘:wx.env.USER_DATA_PATH到底存哪了?怎么删?
  • 手把手教你打造个性化动态彩色二维码生成工具(GUI版)
  • 别再死记硬背LTL公式了!用Python+Spot库5分钟搞定互斥锁与进程公平性验证
  • 终极指南:Mantine TypeScript集成实现类型安全组件开发全流程
  • 敬老院管理|基于springboot + vue敬老院管理系统(源码+数据库+文档)
  • XUnity.AutoTranslator深度解析:如何用5层架构重构Unity游戏本地化体验
  • 如何快速掌握Mint语言编译原理:从源码到JavaScript的转换全过程
  • 嵌入式Linux--全志V3s--NOR Flash分区与文件系统实战(一)
  • 计算机毕业设计:Python海洋与淡水渔业资源监控大屏 Flask框架 数据分析 可视化 数据大屏 大数据 机器学习 深度学习(建议收藏)✅
  • 如何利用TypeScript提升clean-code-javascript项目质量:静态类型检查的7大优势
  • 终极指南:PMD与元编程集成如何实现代码生成质量管控
  • Python 爬虫实战:批量抓取免费代理IP地址,提升网络爬虫效率与匿名性
  • 避坑指南:在安卓Termux里用QEMU装Win11最容易踩的5个雷(附解决方案)
  • 镜像视界·普陀研究院:厘米级无感定位,开启全域无设备空间智能革命
  • wxBot数据库集成终极指南:实现消息持久化与历史记录管理