码迷,mamicode.com
首页 > 编程语言 > 详细

Java冒泡排序

时间:2018-05-05 18:15:10      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:循环   推荐   code   ring   分享   int   原理   代码   技术   

说明:欢迎批评指正,留言点赞!如若转载,请注明原文地址:http://www.cnblogs.com/chris0710/p/8995234.html

这篇文章将通过简单例子说明冒泡排序原理,闲话少说,直接上代码。

 1 /**
 2  * 冒泡排序
 3  * 4, 6, 2, 3, 5
 4  * 思路:先写内循环(遍历次数: times = arr.length - 1),排好第一个数字,再添加外循环,排好所有数字
 5  * 遍历第一次结果:
 6  * _____________
 7  * 4, 6, 2, 3, 5
 8  * 4, 2, 6, 3, 5
 9  * 4, 2, 3, 6, 5
10  * 4, 2, 3, 5, 6
11  */
12 public class BubbleSortDemo {
13     public static void main(String[] args) {
14         int[] arr = {4, 6, 2, 3, 5};
15         bubbleSort(arr);
16         for (int i = 0; i < arr.length; i++) {
17             System.out.println(arr[i]); // 2, 3, 4, 5, 6
18         }
19     }
20     /**
21      * 冒泡排序
22      */
23     public static void bubbleSort(int[] arr) {
24         int len = arr.length;
25         int temp = 0;
26         /*
27         外层循环:控制排好第几个数
28         内层循环:控制相邻两个数比较次数
29         二者关系(i < len - 1与j < len - 1 - i):随着外层循环多排好1个数,内层循环就少循环比较一次
30         */
31         for (int i = 0; i < len - 1; i++) {
32             for (int j = 0; j < len - 1 - i; j++) {
33                 if (arr[j] > arr[j+1]) {
34                     temp = arr[j];
35                     arr[j] = arr[j+1];
36                     arr[j+1] = temp;
37                 }
38             }
39         }
40     }
41 
42 }

 

最后:推荐一个超级实用的可视化工具,目的是可以交互式的看到程序每一步的状态及参数是什么,简直perfect!

可视化工具地址:http://www.pythontutor.com/java.html#mode=edit

界面效果图如下:

 

技术分享图片

Java冒泡排序

标签:循环   推荐   code   ring   分享   int   原理   代码   技术   

原文地址:https://www.cnblogs.com/chris0710/p/8995234.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!