<body>
<!--
冒泡排序: [2,5,8,1,4]
原理:
第一次冒泡:从索引为0开始,进行两两比较,如果索引小上的值大于索引大的值,交换位置,最终产生一个最大值放大arr.length-1的位置 (第一次就会产生最大的值哦)
0-1 1-2 2-3 3-4
第二次冒泡:从索引为0开始,进行两两比较,如果索引小上的值大于索引大的值,交换位置,最终产生一个最大值放大arr.length-2的位置
0-1 1-2 2-3
第三次冒泡:从索引为0开始,进行两两比较,如果索引小上的值大于索引大的值,交换位置,最终产生一个最大值放大arr.length-3的位置
0-1 1-2
第四次冒泡:从索引为0开始,进行两两比较,如果索引小上的值大于索引大的值,交换位置,最终产生一个最大值放大arr.length-4的位置
0-1
总结:
1. 如果数组元素有n个,冒泡次数为n-1次
2.
第一次冒泡: 0-1 1-2 2-3 3-4
第二次冒泡: 0-1 1-2 2-3
第三次冒泡: 0-1 1-2
第四次冒泡: 0-1
if(arr[j] > arr[j+1]){ //arr[j]是代表左边的 arr[j+1]是代表右边的值
i:排序的次数 j:每次排序遍历的索引
1 0 1 2 3(4-i) 2 0 1 2(4-i) 3 0 1(4-i) 4 0(4-i) arr.length-1等于4 j = arr.length-1-i;结束的条件
<script> var arr = [2,5,8,1,4]; //i:排序的次数 for (let i = 1; i <= arr.length-1; i++) { //j:每次排序遍历的索引 for (let j = 0; j <= arr.length-1-i; j++) { if(arr[j] > arr[j + 1]){ //小标为0的与下标为1的值做比较 let temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } console.log(arr); </script>