冒泡排序

文章目录
  1. 1. 基本介绍
  2. 2. 算法描述
  3. 3. 代码实现
  4. 4. 参考

基本介绍

冒泡排序(Bubble Sort)需要重复的走访要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来,使值较大的元素逐渐从前移向后边。

冒泡排序 Bubble Sort

算法描述

冒泡排序算法的运作如下:

  1. 比较相邻的元素。如果第一个比第二个大,就交换
  2. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数
  3. 针对所有的元素重复以上的步骤,除了最后一个
  4. 持续每次对越来越少的元素重复上面的步骤 1 ~ 3,直到没有任何一对数字需要比较

代码实现

private static void bubbleSort(int[] arr) {
// 临时变量
int temp = 0;
// 标识变量,表示是否进行过交换
boolean flag = false;
for (int i = 0; i < arr.length - 1; i++) {
for (int j = 0; j < arr.length - 1 - i; j++) {
// 如果前面的数比后面的数大,则交换
if (arr[j] > arr[j + 1]) {
flag = true;
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}

// 在一趟排序中,一次交换都没有发生过
if (!flag) {
break;
} else {
flag = false;
}
}
}

参考

http://cmsblogs.com/?p=4697