一、前言
冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。(来自百度百科)
二、原理
冒泡排序算法的原理如下:
-
比较相邻的元素。如果第一个比第二个大,就交换他们两个。
-
对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
-
针对所有的元素重复以上的步骤,除了最后一个。
-
持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较
三、图例
动态图(借鉴):
静态遍历图:
四、代码示例
@Test
public void test2(){
int[] nums = {9,1,10,2,8};
int length = nums.length;
// 第一个for 旨在遍历所有元素
for (int i=0;i< length;i++){
// true 表示两个元素已经不需要比较,则退出遍历
boolean flag = true;
// 第二个 for 旨在元素一前一后变动元素位置(元素比较)。length -1-i: -1 表示最后一个元素不需要比较。-i表示遍历i次后的元素i个不需要比较,因为每次遍历,都将大的往后移,最后面的元素都是大的
for (int j=0;j<length -1-i;j++){
// 前后位置比较
if (nums[j] >nums[j+1]){
// 定临时值tmp
int tmp = nums[j];
// 相邻的元素交换位置,既是第一个位置被赋予第二个位置的元素
nums[j] = nums[j+1];
// 后面的元素被赋予前面的元素。至此,两个元素的位置交换完毕
nums[j+1] = tmp;
//false 表示元素之间还可以比较
flag = false;
}
}
// 若无排序,则跳出
if (flag){
break;
}
}
System.out.println("冒泡排序法:"+ Arrays.toString(nums));
}
学习链接: