## 思考:
> 其实关键节点就在于在序列中找到值等于待查找元素值时的处理。如果此时 $mid 位置已经到了序列的最左边,不能再往左了,或者序列中索引小于 $mid 的上一个元素值不等于待查找元素值,那么此时 $mid 就是第一个等于待查找元素值的位置;否则还要继续往前找。
## 代码:
~~~
/**
* 二分查找
* @param $nums
* @return mixed
*/
function binary_search($nums,$num){//传入数组和需要查找的数据
if(count($nums) <= 1){
return 0;
}
return binary_search_internal($nums,$num,0,count($nums)-1);
}
function binary_search_internal($nums,$num,$low,$high){
if($low>$high){
return -1;
}
$mid = floor(($low+$high)/2);
if($num>$nums[$mid]){
return binary_search_internal($nums,$num,$mid+1,$high);
}elseif($num<$nums[$mid]){
return binary_search_internal($nums,$num,$low,$mid-1);
}else{
//区别就在这里 开始
if($mid ==0 || $nums[$mid-1] != $num){//判断是否到了最左边,或者是左边的值不等于要查找的值,因为这是一个有序的数组
return $mid;
}else{
return binary_search_internal($nums,$num,$low,$mid-1);
}
//区别就在这里 结束
}
}
$nums = [1,2,2,3,4,5,6];
$index = binary_search($nums,2);
print $index;
~~~
## 查找最后一个类似
代码不同之处:
~~~
}else{
if($mid ==count($nums)-1 || $nums[$mid+1] != $num){
return $mid;
}else{
return binary_search_internal($nums,$num,$mid+1,$high);
}
}
~~~
- PHP操作集合
- 获取字符首字母
- PHP实现定时备份MySQL数据库
- PHP定时发送邮件
- PHP基本语法
- 总结
- 命名空间
- 错误抑制符
- 位运算符
- 原码,反码,补码
- traits
- PHP的反射机制
- const和define的区别
- 语法
- 常用的函数
- 1.变量及打印函数
- 2.引入文件
- 3.常量
- 4.错误处理
- 5.面向对象
- 数据结构与算法
- 结构
- 数组
- 索引
- 散列表(哈希表)
- 栈
- 队列
- 链表
- 算法
- 排序算法
- 插入排序
- 冒泡排序
- 选择排序
- 归并排序
- 快速排序
- 查找算法
- 二分查找
- 二分查找变形版本1:查询数据在序列中第一次出现
- 哈希算法
- 算法复杂度
- Smarty模板引擎
- composer
- yaf
- yaf的安装配置
- 其它
- Java
- JavaSE
- 1.Java发展及JDK安装配置
- 2.Eclipse的下载及安装
- 3.Java开发基础
- 虚拟机
- 2.编辑虚拟机设置
- 1.虚拟机下安装centos
- 3.安装vmtools
- Linux
- 1.vi和vim编辑器
- 2.开机、重启和用户登录注销
- 3.用户管理
- 4.用户组管理
- 5.用户和组的相关文件
- 6.linux运行级别
- 7.帮助指令
- 8.文件目录类指令
- 9.时间日期类
- 10.搜索查找类
- 11.压缩和解压缩
- 12.组管理和权限管理(难点,重点)
- 虚拟主机的配置
- phpstudy快捷配置
- 配置文件配置
- PHP面向对象高级特性
- SPL标准库(PHP标准库)
- PHP链式操作的实现
- 面向对象编程的基本原则
- 设计模式
- 基本的设计模式