二分查找法
首页->学习资料->数据结构与算法 关键词: 发布时间:2018-07-18 03:45:48 浏览次数:1292

首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;

否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。

重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

<?php

class suanfa
{

    private $data;

    public function __construct()
    {
        $this->data = [87, 22, 5, 1, 2, 8, 3];
    }

    /**
     * 冒泡排序法
     * @return array
     */
    public function maopao()
    {
        $num = count($this->data);
        for ($i = 0; $i < $num; $i++) {
            for ($j = 0; $j < $num - 1; $j++) {
                if ($this->data[$j] > $this->data[$j + 1]) {
                    $temp = $this->data[$j + 1];
                    $this->data[$j + 1] = $this->data[$j];
                    $this->data[$j] = $temp;
                }
            }
        }
        return $this->data;
    }

   

    /**
     * 二分查找法:要求数据必须是升序的
     * @param $x
     * @return int
     */
    public function binsearch($x)
    {
        $a = self::maopao();//先将数据升序排序
        $c = count($a);
        $lower = 0;
        $high = $c - 1;
        while ($lower <= $high) {
            $middle = intval(($lower + $high) / 2);
            if ($a[$middle] > $x) {
                $high = $middle - 1;
            } elseif ($a[$middle] < $x) {
                $lower = $middle + 1;
            } else {
                return $middle;
            }
        }
        return -1;
    }
}

$obj = new suanfa();
print_r($obj->binsearch(22));//5


赞:(0)
踩:(0)
相关文章
冒泡排序法
选择排序法
插入排序法
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:933078
粤ICP备18028092号-1  微信:hurong241