news 2026/5/6 15:19:09

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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
适用场景数据基本有序时效率高数据规模小且交换成本高的场景
算法思想相邻元素比较交换选择最小元素交换到指定位置

四、总结

  • 冒泡排序:适合数据基本有序的场景,通过优化可减少不必要的比较。
  • 选择排序:交换次数少,适合元素交换成本较高的情况(如大型对象排序)。
  • 性能对比:在随机数据下,两者效率相近,但选择排序通常更快(交换次数少)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/6 14:00:23

基于灰狼优化算法GWO的车间调度附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码获取及仿真…

作者头像 李华
网站建设 2026/5/3 21:14:47

PlayCover终极指南:在Apple Silicon Mac上畅玩iOS游戏

PlayCover终极指南&#xff1a;在Apple Silicon Mac上畅玩iOS游戏 【免费下载链接】PlayCover Community fork of PlayCover 项目地址: https://gitcode.com/gh_mirrors/pl/PlayCover 想在M1/M2 Mac上体验《原神》《崩坏&#xff1a;星穹铁道》等热门手游&#xff1f;Pl…

作者头像 李华
网站建设 2026/5/2 10:27:11

智能保险理赔处理系统

智能保险理赔处理系统关键词&#xff1a;智能保险理赔、处理系统、人工智能、机器学习、数据挖掘、自动化流程、风险评估摘要&#xff1a;本文深入探讨了智能保险理赔处理系统&#xff0c;详细介绍了该系统的背景、核心概念、算法原理、数学模型等内容。通过实际案例展示了系统…

作者头像 李华
网站建设 2026/5/1 8:36:13

如何在GitHub上部署Qwen-Image-Edit-2509实现高效图像编辑?

如何在GitHub上部署Qwen-Image-Edit-2509实现高效图像编辑&#xff1f; 在电商运营、社交媒体内容生产和数字创意设计的日常工作中&#xff0c;频繁修改图片已成为常态。然而&#xff0c;依赖Photoshop等专业工具进行手动调整不仅耗时费力&#xff0c;还对操作者的技术水平有较…

作者头像 李华
网站建设 2026/5/1 9:15:47

SLAM文献之A micro Lie theory for state estimation in robotic(1)

摘要 李群&#xff08;Lie group&#xff09;是一种历史悠久的数学抽象对象&#xff0c;其理论可追溯到19世纪&#xff0c;当时数学家 Sophus Lie 奠定了连续变换群理论的基础。此后多年&#xff0c;李群的影响逐渐扩展到科学与技术的诸多领域。近年来&#xff0c;在机器人领域…

作者头像 李华
网站建设 2026/5/6 1:33:58

wiliwili客户端全面故障排查指南:从入门到精通的手柄控制解决方案

大家好&#xff01;作为一款专为手柄控制设计的跨平台B站客户端&#xff0c;wiliwili确实给我们带来了全新的观影体验。但有时候&#xff0c;各种小问题也会让我们头疼不已。别担心&#xff0c;今天我就为大家带来一份超详细的wiliwili故障排查指南&#xff0c;让你轻松解决99%…

作者头像 李华