二分法的算法步骤php,查找算法之二分法

查找算法之二分法

二分法查找的前提是待找的数组是一个有序的数组(这里假设数组是一个从小到大的数组)

递归的查找需要找到的值

思路:首先是一个有序的数组,找到这个数组的中间值,然后需要找到的值和这个中间值比较,如果是比中间值小,就向右递归,否则向左递归

数组 $arr = [2, 36, 25, 1, -1, 45, 99];

待找到的值 -1

/**

* Notes:

* File name:${fILE_NAME}

* Create by: Jay.Li

* Created on: 2019/12/11 0011 17:00

*/

class dichotomy

{

public function searchValue(array $data, int $leftIndex, int $rightIndex, int $findValue)

{

if (!is_array($data)) {

return ['message' => '非数组', 'status' => 0];

}

$middleIndex = floor(($leftIndex + $rightIndex) / 2);//中间值的键

$middleValue = $data[$middleIndex];//中间值

/**

* 递归结束条件

*/

if ($leftIndex > $rightIndex) {

return -1;

}

if ($findValue > $middleValue) {

return $this->searchValue($data, $middleIndex + 1, $rightIndex, $findValue);

} elseif ($findValue < $middleValue) {

return $this->searchValue($data, $leftIndex, $middleIndex - 1, $findValue);

} else {

return $middleIndex;

}

}

}

$obj = new dichotomy();

//$data = [2, 36, 25, 1, -1, 45, 99];

$data = [20,50,60,70,80,90,100,280,290,390,490,490,590,690,790,890,990,1000,10101,1000000];

var_dump($obj->searchValue($data, 0, count($data) - 1, 590));

上述的二分查找法还有一定的局限性,当它找到某个需要的值的时候,就会直接返回,如果有需要得到所有相同的键,目前就不满足了,所以现在需要这样:

/**

* Notes:

* File name:${fILE_NAME}

* Create by: Jay.Li

* Created on: 2019/12/11 0011 17:00

*/

class dichotomy

{

public function searchValue2(array $data, int $leftIndex, int $rightIndex, int $findValue)

{

if (!is_array($data)) {

return ['message' => '非数组', 'status' => 0];

}

$arr = [];

$middleIndex = floor(($leftIndex + $rightIndex) / 2);//中间值的键

if ($middleIndex < $leftIndex || $middleIndex > $rightIndex) {

return ['message' => sprintf("该 [%d] 值不在数组内", $findValue), 'status' => 0];

}

$middleValue = $data[$middleIndex];//中间值

/**

* 递归结束条件

*/

if ($leftIndex > $rightIndex) {

return $arr[] = -1;

}

if ($findValue > $middleValue) {

return $this->searchValue2($data, $middleIndex + 1, $rightIndex, $findValue);

} elseif ($findValue < $middleValue) {

return $this->searchValue2($data, $leftIndex, $middleIndex - 1, $findValue);

} else {

$tempLeft = $middleIndex - 1;

while (true) {

//向左循环,得到所有相同的键

if ($tempLeft < $leftIndex || $data[$tempLeft] != $middleValue) {

//循环退出的条件,当键值越界或者是下一个值和中间值找到的值不相等,退出

break;

}

array_push($arr, $tempLeft);

$tempLeft--;

}

array_push($arr, $middleIndex);

$tempRight = $middleIndex + 1;

while (true) {

//向右循环,得到所有相同的键

if ($tempRight > $rightIndex || $data[$tempRight] != $middleValue) {

break;

}

array_push($arr, $tempRight);

$tempRight++;

}

return $arr;

}

}

}

try {

$obj = new dichotomy();

//$data = [2,3,5,8,8,8, 45, 99];

$data = [20,50,60,70,80,90,100,280,290,390,490,490,590,590,590,590,590,690,790,890,990,1000,10101,1000000];

var_dump($obj->searchValue2($data, 0, count($data) - 1, 100000011));

var_dump($obj->searchValue2($data, 0, count($data) - 1, 590));

} catch (\Exception $e) {

var_dump($e->getMessage());

}

本作品采用《CC 协议》,转载必须注明作者和本文链接

LIYi ---- github地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是C++实现顺序查找算法二分法查找算法的示例代码: ```c++ #include <iostream> #include <vector> #include <algorithm> using namespace std; // 顺序查找算法 int seqSearch(vector<int>& nums, int target) { for (int i = 0; i < nums.size(); i++) { if (nums[i] == target) { return i; } } return -1; // 查找失败 } // 二分法查找算法 int binarySearch(vector<int>& nums, int target) { int left = 0, right = nums.size() - 1; while (left <= right) { int mid = (left + right) / 2; if (nums[mid] == target) { return mid; } else if (nums[mid] < target) { left = mid + 1; } else { right = mid - 1; } } return -1; // 查找失败 } int main() { vector<int> nums = {3, 5, 2, 8, 4, 7, 1, 6}; sort(nums.begin(), nums.end()); // 二分法查找算法需要有序表 int target = 4; int index1 = seqSearch(nums, target); // 调用顺序查找算法 int index2 = binarySearch(nums, target); // 调用二分法查找算法 if (index1 != -1) { cout << "顺序查找成功,目标元素下标为:" << index1 << endl; } else { cout << "顺序查找失败,未找到目标元素" << endl; } if (index2 != -1) { cout << "二分法查找成功,目标元素下标为:" << index2 << endl; } else { cout << "二分法查找失败,未找到目标元素" << endl; } return 0; } ``` 以上代码中,我们使用了STL中的vector容器来存储顺序表元素,并使用sort函数对其进行排序,以便二分法查找算法能够正确执行。在main函数中,我们分别调用了顺序查找算法二分法查找算法查找目标元素的值为4。最后,根据返回的下标值,输出查找结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值