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

排序----冒泡排序

时间:2019-04-21 13:01:06      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:lse   冒泡排序   array   com   ret   system   arrays   i+1   动态   

一.原理

  1.1.动态演示图

    技术图片

  1.2.动态图讲解

  冒泡排序每一次将数组最大的结果存放到数组尾部,经过n-1次上述操作,数组即有序.n为数组的长度.

  1.3.数据演示

  原始数据:8 4 7 10 6 5 4 8

  第一次排序过程:4 8 7 10 6 5 4 8  4 7 8 10 6 5 4 8  4 7 8 10 6 5 4 8   4 7 8 6 10 5 4 8  4 7 8 6 5 10 4 8  4 7 8 6 5 4 10 8  4 7 8 6 5 4 8 10

  第二次排序过程:4 7 8 6 5 4 8 10  4 7 8 6 5 4 8 10  4 7 6 8 5 4 8 10   4 7 6 5 8 4 8 10  4 7 6 5 4 8 8 10  4 7 6 5 4 8 8 10

  .....

二.代码实现

  

public class ArraySortUtils {

/**
* 冒泡排序
* @param array
*/
public static void bubbleSort(int[] array){
//要排序的次数
for(int i = 0; i < array.length -1; i++){
//每次排序将最大值存放到数组最后
for(int j = 0; j < array.length - i -1; j++){
//若前面的值大于后面进行交换
if(array[j] > array[j + 1]){
int temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
System.out.println("第" + (i+1) +"排序的结果为:" + arrayToString(array) );
}
}

/**
* 返回数组的字符串
* @param array
* @return
*/
public static String arrayToString(int[] array){
StringBuilder sb = new StringBuilder("[");
for (int i = 0; i < array.length; i++) {
if( i != (array.length - 1)){
sb.append(array[i] + ",");
}else{
sb.append(array[i] + "]");
}
}
return sb.toString();
}
}


public class ArraySortUtilsDemo {

public static void main(String[] args) {
//第一次 4 7 8 6 5 4 8 10
//第二次 4 7 6 5 4 8 8 10
int[] array = new int[]{8,4,7,10,6,5,4,8};
System.out.println("排序前:" + ArraySortUtils.arrayToString(array));
ArraySortUtils.bubbleSort(array);
System.out.println("排序后:" + ArraySortUtils.arrayToString(array));
}
}

三.演示结果

  排序前:[8,4,7,10,6,5,4,8]

  第1排序的结果为:[4,7,8,6,5,4,8,10]

  第2排序的结果为:[4,7,6,5,4,8,8,10]

  第3排序的结果为:[4,6,5,4,7,8,8,10]

  第4排序的结果为:[4,5,4,6,7,8,8,10]

  第5排序的结果为:[4,4,5,6,7,8,8,10]

  第6排序的结果为:[4,4,5,6,7,8,8,10]

  第7排序的结果为:[4,4,5,6,7,8,8,10]

  排序后:[4,4,5,6,7,8,8,10]

  

排序----冒泡排序

标签:lse   冒泡排序   array   com   ret   system   arrays   i+1   动态   

原文地址:https://www.cnblogs.com/NTBLL/p/10744543.html

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