C#冒泡排序

一、冒泡排序基本原理

冒泡排序是一种简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

以一个简单的整数数组为例,假设数组为[5, 4, 3, 2, 1]。第一轮比较时,首先比较第一个元素5和第二个元素4,因为5>4,所以交换它们的位置,数组变为[4, 5, 3, 2, 1]。接着比较第二个元素5和第三个元素3,因为5>3,交换后数组变为[4, 3, 5, 2, 1],以此类推。经过第一轮比较(总共比较n-1次,n是数组元素个数),最大的元素5就会 "浮" 到数组的最后面。然后进行第二轮比较,此时不需要比较最后一个元素了,因为它已经是最大的。经过n-1轮这样的比较,数组就会排序完成。

二、C#实现冒泡排序的代码示例

以下是一个简单的C3方法来实现的冒泡排序,用于对一个整数数组进行排序:

在上述代码中:

BubbleSort方法接受一个整数数组array作为参数。首先获取数组的长度n

外层循环for (int i = 0; i < n - 1; i++)控制排序的轮数,总共需要n-1轮。

内层循环for (int j = 0; j < n - i - 1; j++)用于每一轮比较元素。在每一轮中,比较相邻的元素,如果array[j]>array[j + 1],就交换它们的位置。交换元素的操作通过一个临时变量temp来实现。

Main方法中,首先定义了一个未排序的整数数组numbers,然后调用BubbleSort方法对其进行排序,最后使用foreach循环输出排序后的数组元素。

C#练习26

相关推荐
bu_shuo4 小时前
计算机二级学习-查找和排序
学习·算法·排序算法
Sam09275 小时前
【AI 算法精讲 13】朴素贝叶斯:文本分类的基石
人工智能·python·算法·ai
SilentSamsara5 小时前
模型可解释性业务化:SHAP/LIME 的业务汇报与合规审查
人工智能·算法·机器学习·自动化
byte轻骑兵5 小时前
【LE Audio】CSIP精讲[5]: 蓝牙协同设备组的安全防护体系与实战规范
算法·安全·音频·le audio·低功耗音频
剑挑星河月5 小时前
35.搜索插入位置
java·数据结构·算法·leetcode
闪电悠米5 小时前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100
人道领域5 小时前
【LeetCode刷题日记】51.N皇后
数据结构·算法
古城小栈14 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby14 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
Turbo正则15 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数