首页 后端开发 php教程 php二分查找二种实现示例_PHP

php二分查找二种实现示例_PHP

Jun 01, 2016 am 11:55 AM
二分查找

php二分查找示例

二分查找常用写法有递归和非递归,在寻找中值的时候,可以用插值法代替求中值法。
当有序数组中的数据均匀递增时,采用插值方法可以将算法复杂度从中值法的lgN减小到lglgN

复制代码 代码如下:
/**
 * 二分查找递归解法
 * @param type $subject
 * @param type $start
 * @param type $end
 * @param type $key
 * @return boolean
 */
function binarySearch_r($subject, $start, $end, $key)
{

 if ( $start >= $end ) return FALSE;
 $mid = getMidKey($subject, $start, $end, $key);
 if ( $subject[$mid] == $key ) return $mid;
 if ( $key > $subject[$mid] ) {
  return binarySearch($subject, $mid, $end, $key);
 }
 if ( $key   return binarySearch($subject, $start, $mid, $key);
 }
}

/**
 * 二分查找的非递归算法
 * @param type $subject
 * @param type $n
 * @param type $key
 */
function binarySearch_nr($subject, $n, $key)
{
 $low = 0;
 $high = $n;
 while ( $low   $mid = getMidKey($subject, $low, $high, $key);
  if ( $subject[$mid] == $key ) return $mid;
  if ( $subject[$mid]    $low = $mid + 1;
  }
  if ( $subject[$mid] > $key ) {
   $high = $mid - 1;
  }
 }
}
function getMidKey($subject, $low, $high, $key)
{
 /**
  * 取中值算法1 取中值 不用 ($low+$high)/2的方式是因为 防止low和high较大时候,产生溢出....
  */
 //return round($low + ($high - $low) / 2);

 /**
  * 经过改进的插值算法求中值,当数值分布均匀情况下,再降低算法复杂度到lglgN
  * 取中值算法2
  */
 return round( (($key - $subject[$low]) / ($subject[$high] - $subject[$low])*($high-$low) ) );
}

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用C#编写二分查找算法 如何使用C#编写二分查找算法 Sep 19, 2023 pm 12:42 PM

如何使用C#编写二分查找算法

使用C语言编写的二分查找程序,使用pthread进行多线程处理 使用C语言编写的二分查找程序,使用pthread进行多线程处理 Aug 26, 2023 pm 12:45 PM

使用C语言编写的二分查找程序,使用pthread进行多线程处理

如何使用java实现二分查找算法 如何使用java实现二分查找算法 Sep 19, 2023 pm 12:57 PM

如何使用java实现二分查找算法

如何使用Python实现二分查找算法? 如何使用Python实现二分查找算法? Sep 20, 2023 pm 01:24 PM

如何使用Python实现二分查找算法?

如何使用二分查找算法在C语言中找到数组中的最小元素? 如何使用二分查找算法在C语言中找到数组中的最小元素? Aug 25, 2023 pm 08:37 PM

如何使用二分查找算法在C语言中找到数组中的最小元素?

使用二分查找算法找到一个数的立方根的Java程序 使用二分查找算法找到一个数的立方根的Java程序 Aug 28, 2023 pm 01:33 PM

使用二分查找算法找到一个数的立方根的Java程序

在C程序中,使用二分查找算法来搜索有理数,而不使用浮点数算术 在C程序中,使用二分查找算法来搜索有理数,而不使用浮点数算术 Aug 27, 2023 pm 06:05 PM

在C程序中,使用二分查找算法来搜索有理数,而不使用浮点数算术

PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素? PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素? Sep 19, 2023 pm 01:14 PM

PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素?

See all articles