事例1
{6,3,8,2,9,1}
第一轮:
第1次:arr[0]与arr[1]比较,6>3成立,就交换,{3,6,8,2,9,1}
第2次:arr[1]与arr[2]比较,6>8不成立,不交换{3,6,8,2,9,1}
第3次:arr[2]与arr[3]比较,8>2成立,就交换,{3,6,2,8,9,1}
第4次:arr[3]与arr[4]比较,8>9不成立,不交换{3,6,2,8,9,1}
第5次:arr[4]与arr[5]比较,9>1成立,就交换,{3,6,2,8,1,9}
第一轮结果:{3,6,2,8,1,9} 9已经到达正确位置,下一轮不用在参与
第二轮:
第1次:arr[0]与arr[1]比较,3>6不成立,不交换{3,6,2,8,1,9}
第2次:arr[1]与arr[2]比较,6>2成立,就交换,{3,2,6,8,1,9}
第3次:arr[2]与arr[3]比较,6>8不成立,不交换{3,2,6,8,1,9}
第4次:arr[3]与arr[4]比较,8>1成立,就交换,{3,2,6,1,8,9}
第二轮结果:{3,2,6,1,8,9} 8已经到达正确位置,下一轮不用在参与
第三轮:
第1次:arr[0]与arr[1]比较,3>2成立,就交换,{2,3,6,1,8,9}
第2次:arr[1]与arr[2]比较,3>6不成立,不交换{2,3,6,1,8,9}
第3次:arr[2]与arr[3]比较,6>1成立,就交换,{2,3,1,6,8,9}
第三轮结果:{2,3,1,6,8,9} 6已经到达正确位置,下一轮不用在参与
第四轮:
第1次:arr[0]与arr[1]比较,2>3不成立,不交换{2,3,1,6,8,9}
第2次:arr[1]与arr[2]比较,3>1成立,就交换,{2,1,3,6,8,9}
第四轮结果:{2,1,3,6,8,9} 3已经到达正确位置,下一轮不用在参与
第五轮
第1次:arr[0]与arr[1]比较,2>1成立,就交换,{1,2,3,6,8,9}
第五轮结果:{1,2,3,6,8,9} 2已经到达正确位置,下一轮不用在参与
剩下1,肯定是最小的了,不用比较了
6个元素,比较了5轮, n个元素需要n-1轮
每一轮比较很多次
事例2
char[] arr = {'h','e','l','l','o','j','a','v','a'};
for(int i=1; i<arr.length; i++){//外循环的次数 = 轮数 = 数组的长度-1
/*
第1轮,i=1,从右到左两两比较,arr[8]与arr[7],arr[7]与arr[6]....arr[1]与arr[0]
第2轮,i=2,从右到左两两比较,arr[8]与arr[7],arr[7]与arr[6]....arr[2]与arr[1]
...
第8轮,i=8,从右到左两两比较,arr[8]与arr[7]
arr[j]与arr[j-1]
找两个关键点:(1)j的起始值:8(2)找j的终止值,依次是1,2,3,。。。8,得出j>=i
*/
for(int j=8; j>=i; j--){
//从大到小,后面的元素 > 前面的元素,就交换
if(arr[j]>arr[j-1]){
int temp = arr[j];
arr[j] = arr[j-1];
arr[j-1] = temp;
}
}
}