微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

冒泡算法

<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,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>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐