javascript二分法数组排序

这段代码展示了如何用JavaScript实现二分法对数组进行排序。通过递归地将数组分成左右两部分,分别比较元素与中间值的关系,然后合并排序后的子数组,最终完成整个数组的排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<script type="text/javascript">
function twoSort(arr){
//最后当数组长度只有一的时候,不再往下执行
if (arr.length<=1) {
return arr;
}
var middle=arr.splice(Math.floor(arr.length/2),1);
var leftArr=[];
var rightArr=[];
for(var i=0; i<arr.length; i++){
       if(parseInt(arr[i])<=middle){
           leftArr.push(arr[i]);       //把比中间值小的放一个数组
       }else{
           rightArr.push(arr[i]);      //把比中间值大的放另一个数组
       }
    }
    //concat() 方法用于连接两个或多个数组。
    //再对小数组继续回调上面的分组方法
return twoSort(leftArr).concat(middle,twoSort(rightArr));
}
var arr=[565,77,89,45,34,12,65,31,121];
var nowArr=twoSort(arr);
document.write(nowArr);
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值