八大排序相对应链接
冒泡排序的基本原理
对存放原始数组的数据,按照从前往后的方向进行多次扫描,每次扫描都称为一趟。当发现相邻两个数据的大小次序不符合时,即将这两个数据进行互换,如果从小大小排序,这时较小的数据就会逐个往前移动,好像气泡网上漂浮一样。
冒泡排序的特点:
升序排序当中每一轮比较会把最大的数沉到最底(这里以从小到大为例),所有相互比较的次数每一轮会比前一轮少一次。
代码 import java.util.Arrays; //冒泡 public class Test01 { public static void main(String[] args) { int[] arr = new int[]{615,156,1,65,16316,14156,44}; sort(arr); System.out.println(Arrays.toString(arr));//输出排序好的数组 } public static void sort(int[] arr){ for (int i =0;i<arr.length;i++){ //外层循环 控制执行的次数 for (int j=0;j<arr.length-1;j++){ //内层循环 数据两两交换 if (arr[j]> arr[j+1]){ int temp = arr[j]; arr[j]= arr[j+1]; arr[j+1] =temp; } } } } }
代码解析:该算法代码由外层循环和内层循环组成,内层循环包括比较大小语句和互换位置语句
外层循环主要是控制代码的执行次数,内层循环主要是进行比较和位置交换
外层循环每次循环都是将最最大的数放到最后边所以内层循环每次都需要减 -1