码迷,mamicode.com
首页 > 编程语言 > 详细

折中算法

时间:2016-08-17 18:02:39      阅读:438      评论:0      收藏:0      [点我收藏+]

标签:

前提:数组是有序的

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

折中算法

标签:

原文地址:http://www.cnblogs.com/luckyXcc/p/5780996.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!