专业编程基础技术教程

网站首页 > 基础教程 正文

C#基础语法循环篇:冒泡排序算法讲解(附源码)

ccvgpt 2024-12-29 01:49:10 基础教程 7 ℃

大家好,今天我给大家示例顺便讲解一个C#里面的经典的循环算法之冒泡排序,可供一些初级C#或者Java程序员参考学习。

其原理:比较相邻的两个元素,每次比较完毕最大的一个数字排到本来的结尾

C#基础语法循环篇:冒泡排序算法讲解(附源码)

目的:按照从小到大的排序方式。

先预设已知数组一份:23, 67, 45, 19, 83, 36, 42, 15, 71, 52

第一轮比较相邻两个元素,如果左边元素大于右边元素,则两两交换。

比如71和52比较的结果就是,52在前,71在后;

然后71和67比较的结果,67在前,71在后;

以此类推,第一轮比较之后的结果是:23, 45, 19, 67, 36, 42, 15, 71, 52, 83

经过第一轮比较,最大的元素跑到了最后一个,所以第二轮比较,最后一个元素不需要进行比较了。

第二轮还是从索引0和1开始比较,只是不需要比较最后一个了,算法还是一样的。第三轮、第四轮以此类推。

排序之后的结果为:15, 19, 23, 36, 42, 45, 52, 67, 71, 83

核心代码如下:

for (int i = list.Count; i > 0; i--)//外层 循环比较遍数

{

for (int j = 0; j < i - 1; j++)

{

// 大于号就是从小到大排序,小于号就是从大到小排序

if (list[j] > list[j + 1]) //两个数进行比较,如果大于就交换

{

temp = list[j]; //temp 两个数交换时要有第三个数来过度

list[j] = list[j + 1];

list[j + 1] = temp;

}

}

Prin();

}

出结果:

23 45 19 67 36 42 15 71 52 83

23 19 45 36 42 15 67 52 71 83

19 23 36 42 15 45 52 67 71 83

19 23 36 15 42 45 52 67 71 83

19 23 15 36 42 45 52 67 71 83

19 15 23 36 42 45 52 67 71 83

15 19 23 36 42 45 52 67 71 83

Tags:

最近发表
标签列表