递归二分查找 望各位大哥大姐 帮忙 求解释
$Arr=array(1,2,3,4,5,6);
Search($Arr,6,0,count($Arr)-1);
function Search($Arr,$FindVal,$LeftIndex,$RightIndex){
if($FindVal>$Arr[count($Arr)-1]){
echo "找不到该值";
}else if($FindVal echo "找不到该值";
}else{
$MiddleIndex=round(($LeftIndex+$RightIndex)/2);
if ($Arr[$MiddleIndex] Search($Arr,$FindVal,++$MiddleIndex,$RightIndex);
}else if($Arr[$MiddleIndex]>$FindVal){
Search($Arr,$FindVal,$LeftIndex,--$MiddleIndex);
}else{
echo "找到下标为$MiddleIndex";
}
}
}
?> 这是递归的二分查找的代码 求高手细致深入解释 目前对这个递归的方法 不知道是怎么实现的 望深入解释 尤其是每次判断符合条件时候 然后再次调用函数 我就有点晕了 谢谢大家帮忙解释
回复讨论(解决方案)
还有 今后实际开发的过程中 涉及算法还有这类查找的知识用的多不多?
当满足这个条件时 if ($Arr[$MiddleIndex] Search($Arr,$FindVal,++$MiddleIndex,$RightIndex);
这里的++$MiddleIndex 返回的值 是不是把$LeftIndex给替换了?
等于返回后 function Search($Arr,$FindVal,$LeftIndex,$RightIndex) 这里的值 分别是$Arr $FindVal还是6 $LeftIndex就等于了之前的$MiddleIndex 也就是等于了4? 这样理解对吗
你在函数入口处加上
echo "FindVal:$FindVal LeftIndex:$LeftIndex RightIndex:$RightIndex\n";
不就看清楚了吗?
教你怎么画时序图,自己多分析
非常感谢 还有个问题就是 第二次调用Search($Arr,$FindVal,++$MiddleIndex,$RightIndex); 的时候 里面的 变量位置不可以改变吗? 比如写成这样?Search($Arr,$FindVal,$RightIndex,++$MiddleIndex);
在不基于你发出代码的前提下,函数的内部和外部的变量名没有任何联系,所以可以次序可以任意改变。
就拿上边的时序图来说,你可以认为每一个纵列都是一个全新的环境,例如有3个纵列都有变量$a,但是它们指代不同的事物(内存空间)
全局环境下的$a | 第一次函数环境下的$a | 第二次函数环境下的$a
尽管从名字上都一样,但是它们确实不同
就好像一楼有张三,二楼有张三,三楼有张三,是指3个人,而不是同一个人,因为他们所处的环境不一样。
但是基于你发出代码的逻辑来说,就不能换了,因为环境1中的$RightIndex和环境2中$RightIndex都需要相同值,所以不能换。
教你怎么画时序图,自己多分析
你好,看了你的时序图,如果要查找的数组是 $arr=array(1,3,4,5,7,8,9),我发现要套好几层的函数。是我理解错误,还是确有此事,请教一下。谢谢。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

The Storage::download method of the Laravel framework provides a concise API for safely handling file downloads while managing abstractions of file storage. Here is an example of using Storage::download() in the example controller:

Laravel simplifies HTTP verb handling in incoming requests, streamlining diverse operation management within your applications. The method() and isMethod() methods efficiently identify and validate request types. This feature is crucial for building
