这篇文章主要介绍了PHP实现二维数组中的查找算法,涉及PHP数组遍历、判断、计算等相关操作技巧,需要的朋友可以参考下
本文实例讲述了PHP实现二维数组中的查找算法。分享给大家供大家参考,具体如下:
方法1:silu从左下角最后一行的第一个元素开始,遍历。如果小于target 则遍历该行的所有元素,找到结束。如果大于继续往上一行进行。等于直接结束。
<?php
function Find($target, $array)
{
  $m_y = count($array['0']);
  $m_x = count($array);
  for($i=$m_x-1;$i>=0;$i--){
    if($array[$i]['0'] < $target){
      for($j=1;$j<$m_y;$j++){
        if($array[$i][$j] == $target){
          return 1;
          break;
        }
      }
    }
    if($array[$i]['0'] == $target){
      return 1;
      break;
    }
  }
}
方法2:
function Find($target, $array)
{
  $m_y = count($array['0']);
  $m_x = count($array);
  $i = 0;
    for($i =$m_x-1,$j=0;$i>=0&&$j<$m_y;){
      if($array[$i][$j]<$target){
        $j++;
        continue;
      }
      if($array[$i][$j]>$target){
        $i--;
        continue;
      }
      if($array[$i][$j] == $target){
        return 1;
      }
    }
}
方法3:
function Find($target, $array)
{
  $m_y = count($array['0']);
  $m_x = count($array);
  $i = $m_x-1;
  $j = 0;
  while(1){
    if($array[$i][$j]<$target){
      $j++;
    }
    if($array[$i][$j]>$target){
      $i--;
    }
    if($array[$i][$j] == $target){
      return 1;
    }
    if($i == 0||$j == $m_y-1){
      return 0;
    }
  }
}
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》及《PHP数学运算技巧总结》
希望本文所述对大家PHP程序设计有所帮助。
				 沃梦达教程
				
			本文标题为:PHP实现二维数组中的查找算法小结
				
        
 
            
        
             猜你喜欢
        
	     - windows下9款一键快速搭建PHP本地运行环境的好工具(含php7.0环境) 2023-09-02
 - PHP中PDO事务处理操作示例 2022-10-15
 - laravel通用化的CURD的实现 2023-03-17
 - 用nohup命令实现PHP的多进程 2023-09-02
 - PHP仿tp实现mvc框架基本设计思路与实现方法分析 2022-10-18
 - laravel实现按月或天或小时统计mysql数据的方法 2023-02-22
 - PHP实现微信支付(jsapi支付)流程步骤详解 2022-10-09
 - PHP简单实现二维数组的矩阵转置操作示例 2022-10-02
 - Laravel balde模板文件中判断数据为空方法 2023-08-30
 - php微信公众号开发之秒杀 2022-11-23
 
						
						
						
						
						
				
				
				
				