Web_java script冒泡排序法及四次优化详解

冒泡排序法,从小到大排序

var arr=[8,1,5,3,7];
console.log("操作前原数组:",arr);
for(var j=0;j<arr.length-1;j++){
	var boo=true;
	for(var i=0;i<arr.length-1-j;i++){
		if(arr[i+1]){
			boo=false;
			var temp=arr[i];
			arr[i]=arr[i+1];
			arr[i+1]=temp;
		}
		console.log("第"+j+"轮"+"第"+i+"次");
	}
	console.log("本次交换完数组:",arr);
	if(boo){
	//如果本轮完事,没有执行if语句,表示前面没有比后面小的,也就是前面比后面大,那么就是有顺序的了,可停止循环。
		break;
	}
}
console.log("操作后的原数组",arr);

控制台打印内容,如下

操作前原数组: (5) [8, 1, 5, 3, 7]0轮第0次
第0轮第1次
第0轮第2次
第0轮第3本次交换完数组: (5) [1, 5, 3, 7, 8]1轮第0次
 第1轮第1次
第1轮第2本次交换完数组: (5) [5, 3, 7, 1, 8]2轮第0次
第2轮第1本次交换完数组: (5) [3, 7, 5, 1, 8]3轮第0本次交换完数组: (5) [7, 3, 5, 1, 8]
操作后的原数组 (5) [7, 3, 5, 1, 8]

冒泡排序法四次优化

  1. 内层for循环:变量<.length-1;
    原因:最后一个数,不能和后面比较,所以最大索引是倒数第二个索引。
  2. 外层for循环:变量<.length-1;
    原因:n个数,冒泡(n-1)次就会出现顺序。
  3. 内层for循环:变量<.length-1-外层for循环变量;
    原因:每轮冒泡结束后,就会诞生一个最下值,下一轮可少比较一次。
  4. 开闭原则:排出顺序立即停止。

开闭原则:在面向对象编程领域中,开闭原则规定“软件中的对象(类,模块,函数等等)应该对于扩展是开放的,但是对于修改是封闭的”,这意味着一个实体是允许在不改变它的源代码的前提下变更它的行为。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值