折中算法

前提:数组是有序的

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

</body>

<script type="text/javascript">

var resultArray = [5,3,10,7,6];

//标记的思想

function sortNum(a, b){

return a-b;

}

resultArray = resultArray.sort(sortNum);

console.log(resultArray);

var min = 0;

var max = resultArray.length - 1;

var index = -1;//用来记录最终找到的结果

for (var i = 0;i < resultArray.length / 2;i++) {

//需要查找的下标

var middle = parseInt((min + max) / 2);

//console.log(middle);

if (resultArray[middle] == 7) {

index = middle;

console.log(index);

break;

}else if(resultArray[middle] < 7){

min = middle + 1;

}else{

max = middle;

}

}

if (index != -1) {

console.log("7这个元素在数组的下标为:" + index);

}

</script>

</html>

转载于:https://www.cnblogs.com/luckyXcc/p/5780996.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值