0

0

C# 冒泡排序实现方法 C#如何实现冒泡排序算法

星降

星降

发布时间:2026-01-24 04:01:06

|

609人浏览过

|

来源于php中文网

原创

冒泡排序核心逻辑需控制内外循环边界:外层i从0到n-2,内层j从0到n-2-i,避免越界;升序时arr[j]>arr[j+1]交换,降序则相反;高频场景宜用Span优化但不可返回局部Span;实际项目中因O(n²)性能差,应优先使用Array.Sort()。

c# 冒泡排序实现方法 c#如何实现冒泡排序算法

冒泡排序的核心逻辑怎么写才不越界

冒泡排序本质是相邻元素两两比较、交换,每轮把最大(或最小)值“浮”到一端。C# 中最易出错的是循环边界——ij 的取值范围稍有偏差,就会导致 IndexOutOfRangeException

关键点:外层控制轮数,最多 n-1 轮;内层控制比较范围,第 i 轮只需比到 length - 1 - i 位置。

  • 数组长度为 n,下标范围是 0n-1j+1 最大不能超过 n-1 → 所以 j 最大只能是 n-2
  • 每轮结束后,末尾 i 个元素已有序,内层循环上限应动态收缩:j
  • 若用 for (j = 0; j ,则 j+1 在最后一轮会越界

升序和降序只差一个比较符,但别写反了

升序是“前面 > 后面 就交换”,降序是“前面 arr[j] 却声称要升序,结果排出来是逆序——这不是算法错,是语义理解反了。

建议统一用“目标顺序 + ‘应交换’的条件”来校验:

  • 升序:大的该往后走 → arr[j] > arr[j + 1] 时交换
  • 降序:小的该往后走 → arr[j] 时交换
  • 泛型版本中,用 comparer.Compare(arr[j], arr[j + 1]) > 0 更安全,避免手动写错符号

用 Span 优化性能时要注意生命周期

在高频或大数据量场景下,直接操作 Span 可避免数组拷贝和 GC 压力,但必须确保 Span 不逃逸出当前作用域

萝卜简历
萝卜简历

免费在线AI简历制作工具,帮助求职者轻松完成简历制作。

下载

错误示例:Span s = array.AsSpan(); return s; —— 返回局部 Span 会导致未定义行为。

  • 正确做法:把排序逻辑封装为 void Sort(Span span),只在上操作
  • ReadOnlySpan 无法排序(不可变),必须用可写的 Span
  • 若原始数据是 List,先调 list.AsSpan(),但注意 List 内部数组可能被扩容,需确保未发生结构变更

实际项目中为什么几乎不用手写冒泡

冒泡排序时间复杂度恒为 O(n²),即使加了“提前退出”优化(检测某轮无交换就终止),最坏和平均仍是 O(n²)。.NET 自带的 Array.Sort() 底层是 introsort(快排 + 堆排 + 插入排序混合),实测百万整数排序比手写冒泡快 300 倍以上。

真正需要手写冒泡的场景极少,典型如:

  • 教学演示算法思想(强调交换过程)
  • 嵌入式或极简运行时环境(无 System.Array 排序 API)
  • 调试时临时对小数组做可视化排序步骤跟踪

只要不是为了理解过程本身,优先用 Array.Sort(arr)arr.OrderBy(x => x).ToArray()——省心,且编译器和 JIT 会做大量优化。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

358

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

542

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

98

2025.11.27

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.07.18

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.8万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.7万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号