二分查找法
首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;
否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。
重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。
<?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
- 我的项目
- 【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