排序——冒泡排序

Posted hesc980513

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了排序——冒泡排序相关的知识,希望对你有一定的参考价值。

 1 /*
 2  * int类型的数组对象
 3  * int[] arr = {9, 8, 10, 7, 6, 0, 11};
 4  * 经过冒泡排序对以上数组中的元素进行排序
 5  * 
 6  * 原始数据:9,8,10,7,6,0,11
 7  * 第一次循环:    第零位9跟第一位8进行比较,交换位置:8,9,10,7,6,0,11
 8  *             第一位9跟第二位10进行比较,位置不变:8,9,10,7,6,0,11
 9  *            第二位10跟第三位7进行比较,交换位置:8,9,7,10,6,0,11
10  *            第三位10跟第四位6进行比较,交换位置:8,9,7,6,10,0,11
11  *            第四位10跟第五位0进行比较,交换位置:8,9,7,6,0,10,11
12  *            第五位10跟第六位11进行比较,位置不变:8,9,7,6,0,10,11
13  *最大数11冒出
14  *此时数据:8,9,7,6,0,10
15  *第二次循环:    第零位8跟第一位9进行比较,位置不变:8,9,7,6,0,10
16  *             第一位9跟第二位7进行比较,交换位置:8,7,9,6,0,10
17  *            第二位9跟第三位6进行比较,交换位置:8,7,6,9,0,10
18  *            第三位9跟第四位0进行比较,交换位置:8,7,6,0,9,10
19  *            第四位9跟第五位10进行比较,位置不变:8,7,6,0,9,10
20  *最大数10冒出
21  *此时数据:8,7,6,0,9
22  *第三次循环:    第零位8跟第一位7进行比较,交换位置:7,8,6,0,9
23  *             第一位8跟第二位6进行比较,交换位置:7,6,8,0,9
24  *            第二位8跟第三位0进行比较,交换位置:7,6,0,8,9
25  *            第三位8跟第四位9进行比较,位置不变:7,6,0,8,9
26  *最大数9冒出
27  *此时数据:7,6,0,8
28  *第四次循环:    第零位7跟第一位6进行比较,交换位置:6,7,0,8
29  *             第一位7跟第二位0进行比较,交换位置:6,0,7,8
30  *            第二位7跟第三位8进行比较,位置不变:6,0,7,8
31  *最大数8冒出
32  *此时数据:6,0,7
33  *第五次循环:    第零位6跟第一位0进行比较,交换位置:0,6,7
34  *             第一位6跟第二位7进行比较,位置不变:0,6,7
35  * 最大数7冒出
36  * 此时数据:0,6
37  * 第六次循环:    第零位0跟第一位6进行比较,位置不变:0,6
38  * 最大数6冒出
39  */
40 public class MaoPao {
41     public static void main(String[] args) {
42         // 定义要排序的int数组
43         int[] arr = { 9, 8, 10, 7, 6, 0, 11 };
44         // 计算循环的次数(可有可无)
45         int count = 0;
46         for (int i = arr.length - 1; i > 0; i--) {
47             for (int j = 0; j < i; j++) {
48                 count++;
49                 if (arr[j] > arr[j + 1]) {
50                     // 以下三行代码完成数据的交换
51                     int temp;// 暂时存放
52                     temp = arr[j];// 第一个数拿出来
53                     arr[j] = arr[j + 1];// 第二个数放到第一个数的位置
54                     arr[j + 1] = temp;// 第一个数放到第二个数的位置
55                 }
56             }
57         }
58         System.out.println("循环了" + count + "次。");
59         for (int i = 0; i < arr.length; i++) {
60             System.out.println(arr[i]);
61         }
62     }
63 
64 }

最简单的排序算法。

以上是关于排序——冒泡排序的主要内容,如果未能解决你的问题,请参考以下文章

交换排序(冒泡排序快速排序的算法思想及代码实现)

请问这个冒泡排序代码,每一行都是啥意思呀,谢谢

java冒泡排序法代码

排序算法之冒泡选择插入排序(Java)

排序算法之冒泡选择插入排序(Java)

冒泡排序python代码