网站首页 > 精选教程 正文
大家好,今天我给大家示例顺便讲解一个C#里面的经典的循环算法之冒泡排序,可供一些初级C#或者Java程序员参考学习。
其原理:比较相邻的两个元素,每次比较完毕最大的一个数字排到本来的结尾
目的:按照从小到大的排序方式。
先预设已知数组一份: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
- 上一篇: 「算法」冒泡排序图文讲解
- 下一篇: 深圳尚学堂Java培训:排序方法小结-冒泡排序
猜你喜欢
- 2024-12-04 程序入门:冒泡排序(C++)
- 2024-12-04 算法学习-JavaScript冒泡排序与选择排序
- 2024-12-04 西门子SCL编程实例——冒泡排序算法(更新版)
- 2024-12-04 python冒泡排序
- 2024-12-04 C语言 冒泡排序
- 2024-12-04 Python中的关键算法之”冒泡排序“
- 2024-12-04 西门子SCL语言编程实例——冒泡排序
- 2024-12-04 宇哥编程算法练习:冒泡排序的原理(基于Access数据库VBA)
- 2024-12-04 看动画学算法之:排序-冒泡排序
- 2024-12-04 西门子SCL编程实例—冒泡排序算法的实现
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)