二分查找法

二分法:输入必须是一个有序的元素列表

最多需要log2^n步(对数):将2^n=x(假如列表包含8个元素,2^n=8 n=3,最多需要3步可以找到该元素)

练习:

1.假设有一个包含128个名字的有序列表,你要使用二分查找在其中查找一个名字,请 问最多需要几步才能找到?(7步 2^7=128)

2.上面列表的长度翻倍后,最多需要几步?(8步)

代码 :

<?php
//前提条件:必须是一个有序列表
//解题思路:
//1 将数组排序
//2 寻找中间数。中间数=(开始数+结尾数)/2
//3 判断中间数。如果中间数比查找数小,就在中间数和结尾数中查找。反之在开始数和中间数中查找
//4 多次循环,找出查找数的下标
$a = [4,3,3,2,1,1234,3,4,5,6,7,7,8,4,21,3243,54,5,2,32,2,32,3,2,32,32,3,2,14254,5,99,43,65,6,653,65,4];
//$a =[4,3,1,2];
sort($a);
$guess = 324322;

$len = count($a);
$start = 0;
$end = $len -1;

while($len >= $end){
   $mid = intval(($start + $end)/2);
    if ($guess == $a[$mid]){
        echo $mid;exit;
    }
    if ($guess > $a[$mid]) {
        $start= $mid;
    }else{
        $end = $mid;
    }
}

大O表示法:指出最糟情况下的运行时间

二分查找法

 

算法的时间指的是操作数的增速

算法的运行时间是以大O表示法来表示 

 

上一篇:Codeforces1355F Guess Divisors Count


下一篇:每日一练-leetcode