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

Visual Studio中的冒泡排序和选择排序

目录

一、冒泡排序

1.介绍

2.使用模板

3.示例

4.注意事项

二、选择排序

1.介绍

2.使用模板

3.示例

4.注意事项

三、两者对比

四、总结


一、冒泡排序

1.介绍

冒泡排序是一种简单的排序算法,通过相邻元素的比较与交换将最大(或最小)的元素逐步“冒泡”到数组的末端。重复此过程直到整个数组有序。

2.使用模板

3.示例

对数组[3, 1, 4, 1, 5]进行冒泡排序:

  1. 第1轮:比较相邻元素,交换31[1, 3, 1, 4, 5]
  2. 第2轮:交换31[1, 1, 3, 4, 5]
  3. 第3轮:无交换,提前退出。

4.注意事项

  • 优化标志:添加swapped标志可避免不必要的循环,提升效率。
  • 数组越界:内循环条件需为j < n - 1 - i,避免访问array[j+1]时越界。
  • 稳定性:冒泡排序是稳定排序(相同元素相对位置不变)。

二、选择排序

1.介绍

选择排序通过每次从未排序部分选择最小(或最大)元素,将其放到已排序部分的末尾。重复此过程直到整个数组有序。

2.使用模板

3.示例

对数组[3, 1, 4, 1, 5]进行选择排序:

  1. 第1轮:找到最小元素1(索引1),交换到位置0 →[1, 3, 4, 1, 5]
  2. 第2轮:找到最小元素1(索引3),交换到位置1 →[1, 1, 4, 3, 5]
  3. 第3轮:找到最小元素3(索引3),交换到位置2 →[1, 1, 3, 4, 5]

4.注意事项

  • 交换次数少:选择排序交换次数固定为n-1次,优于冒泡排序。
  • 不稳定性:选择排序是不稳定排序(相同元素可能交换位置,例如[2, 2, 1]排序后变为[1, 2, 2],但原顺序可能改变)。
  • 性能:时间复杂度始终为O(n²),无优化空间。

三、两者对比

对比维度冒泡排序选择排序
时间复杂度平均/最坏O(n²),最好O(n)(优化后)始终O(n²)
空间复杂度O(1)(原地排序)O(1)(原地排序)
稳定性稳定不稳定
交换次数最多n(n-1)/2固定n-1
适用场景数据基本有序时效率高数据规模小且交换成本高的场景
算法思想相邻元素比较交换选择最小元素交换到指定位置

四、总结

  • 冒泡排序:适合数据基本有序的场景,通过优化可减少不必要的比较。
  • 选择排序:交换次数少,适合元素交换成本较高的情况(如大型对象排序)。
  • 性能对比:在随机数据下,两者效率相近,但选择排序通常更快(交换次数少)。
http://www.jsqmd.com/news/95386/

相关文章:

  • Python林业资源开发管理系统设计与实现1_2595688s--pycharm Vue django flask项目源码
  • 百度网盘提取码智能助手:如何一键获取分享码的完整指南
  • 终极指南:MouseClick自动连点器如何让工作效率翻倍
  • 基于OpenSpec标准优化的GPT-OSS-20B模型架构剖析
  • 如何快速掌握ITK-SNAP:面向医学研究者的完整指南
  • 3步搞定Vue项目Office文件预览:新手也能快速上手的实用指南
  • 终极指南:在微信小程序中快速集成专业3D渲染的完整教程
  • Git 下载最新版Qwen3-VL-8B模型权重的操作步骤
  • 使用LangChain编排Seed-Coder-8B-Base实现自动化脚本生成
  • 免费开源3D重建神器:用普通照片轻松制作专业级模型
  • 利用HunyuanVideo-Foley和Maven构建自动化视频后期处理流水线
  • Wan2.2-T2V-5B能否用于教育领域?K12课件动画生成尝试
  • 掌握m3u8下载技巧:浏览器扩展让你轻松抓取网页视频
  • 通过DBLINK访问远程数据库
  • gpt-oss-20b在低资源环境下的性能调优技巧
  • 暗黑破坏神II存档修改器:5分钟学会角色属性自由定制
  • C++中1 << 31 - 1相当于INT_MAX吗?
  • Wan2.2-T2V-5B模型在JLink驱动调试可视化中的创新应用
  • HunyuanVideo-Foley实战教程:从GitHub克隆到音效生成全流程解析
  • GitHub Projects管理Qwen-Image-Edit-2509功能开发路线图
  • 三步快速解密音乐文件:免费工具完整指南
  • AdGuardHomeRules:百万级规则构建的智能广告拦截堡垒
  • HuggingFace镜像网站之外的选择:Seed-Coder-8B-Base本地部署教程
  • 如何利用Wan2.2-T2V-A14B实现高质量长视频生成?
  • AVL树的学习
  • 告别手写代码!Formily可视化表单设计器让企业级表单开发效率提升300%
  • 基于Qwen3-32B构建高质量内容生成系统的完整指南
  • 使用Wan2.2-T2V-A14B生成动态广告内容,提升营销转化率
  • 企业微信智能表格高效计算工作人天:日 / 周 / 月全维度公式 + 实操指南
  • 城通网盘极速下载:三步获取文件直链的智能工具