• 技术文章 >后端开发 >php教程

    PHP简单的数组查找算法分享

    小云云小云云2018-03-21 10:28:09原创829
    PHP中对于数组的查找可以用顺序查找或二分法查找。其中顺序查找比较简单,就是逐个比较查找。但缺点也较明显,如果查找的元素恰巧在最后一个,循环的次数过多。

    1.顺序查找算法描述

    在数组中逐个查找,确认是否有某个元素,存在时返回元素的位置信息。可以设置标志信息,初始值为false.找到直接输出位置,并将标志设置为true。循环结束标志仍为false,则没有找到。

    代码体现:


    $arr =[123,19,38,29,10,34];
    function search($arr,$target){
        // 参数:目标数组 目标元素
    	foreach ($arr as $key => $value) {
    		if($value == $target){
    			return $key.'<br>';
    		}
    	}
    	return false;
    }

    2.二分法查找算法描述

    假设数组严格升序。如果目标元素大于中间的值,查找范围向右侧缩小一半。如果目标元素的值小于中间元素的值,查找范围向左侧缩小一半。

    代码体现:

    function half_search($arr,$target){
    	// 定义出初始的第一个,最后一个元素的下标范围
    	$len = count($arr);
    	$left =0;
    	$right =$len -1;
    	// 循环查找
    	// 范围不断的移动 ,必须满足一个条件
    	// 最左侧元素的下标 小于等于右侧元素的下标
    	while($left <= $right){
    	 	// 中间元素的下标
    	 	$middle = floor(($left + $right) /2);
    	 	// 目标元素与中间元素进行比较
    	 	if($target == $arr[$middle]){
    	 		return $middle;
    	 	}
    	 	// 如果目标元素小于中间元素
    	 	// 范围向左缩小一半	
    	 	if($target < $arr[$middle]){
    	 		$right =$middle-1 ;
    	 	}
    	 	// 如果目标元素大于中间元素
    	 	// 范围向右缩小一半
    	 	if($target > $arr[$middle]){
    	 		$left = $middle + 1;
    	 	}
    	}
    	 // 循环终止了
    	 // 没有找到
    	 return false;
    }

    相关推荐:

    PHP二分法实现数组查找功能教程

    php数组查找关键函数

    php数组查找函数总结

    php入门到就业线上直播课:查看学习

    以上就是PHP简单的数组查找算法分享的详细内容,更多请关注php中文网其它相关文章!

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

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:php 分享 算法
    上一篇:PHP插件写入excel文件的方法 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 工具包分享:PHP实现滑块验证图片• Symfony2函数用法实例分析,symfony2实例分析_PHP教程• Drupal读取Excel并导入数据库实例_PHP教程• 使用 PHP 限制下载速度_PHP教程• PHP中的SimpleXML处理_PHP教程
    1/1

    PHP中文网