当前位置:首页 > PHP教程 > php数组 > 列表

php数组比较实现查找连续数的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-06-14 20:52:45 浏览: 评论:0 

这篇文章主要介绍了php数组比较实现查找连续数的方法,实例分析了php数组查找及字符串操作的相关技巧,需要的朋友可以参考下。

本文实例讲述了php数组比较实现查找连续数的方法,分享给大家供大家参考,具体如下:

  1. $data = array(); 
  2. $data[]= array("01" ,"02""18" , "29" , "31" , "32"); 
  3. $data[]= array("02" ,"09""11" , "22" , "24" , "27"); 
  4. $data[]= array("07" ,"16""26" , "27" , "29" , "31"); 
  5. $data[]=array("04""05""07""10""13""25"); 
  6. $data[]=array("02""04""05""08""19""22"); 
  7. $data[]=array("03""04""15""25""26""30"); 
  8. $data[]=array("01""03""06""12""16""32"); 
  9. $data[]=array("01""05""14""17""22"); 
  10. // 判断表格中3个以上的连续  
  11. function checkAll($sourceArr2D) { 
  12.   $count = sizeof($sourceArr2D); 
  13.   for($i=0; $i<$count$i++){ 
  14.     check_h($sourceArr2D[$i], $i);//找寻水平方向 
  15.     if($i>0) { 
  16.       check_v($sourceArr2D$i);// 找寻竖直方向 
  17.       check_l($sourceArr2D$i);// 找寻/方向 
  18.       check_r($sourceArr2D$i);// 找寻方向 
  19.     } 
  20.   } 
  21. // 判断水平方向 
  22. $h = array();// 保存水平方向上的搜寻结果 
  23. function check_h($arr$rownum) { 
  24.   //sort($arr, SORT_NUMERIC); 
  25.   global $h
  26.   $flag = false; 
  27.   for($i=2; $i<6; $i++){ 
  28.     if$arr[$i-2]==$arr[$i]-2 ){ 
  29.     // 因为数组内数字不重复且有序故可取巧 
  30.       if(!$flag) { 
  31.         $h[$rownum] = array($arr[$i-2], $arr[$i-1], $arr[$i]); 
  32.         $flag = true; 
  33.       }else
  34.         array_push($h[$rownum], $arr[$i]); 
  35.       } 
  36.     } 
  37.   } 
  38. // 判断竖直方向 
  39. $v = array();// 保存竖直方向上的搜寻结果 
  40. function check_v($sourceArr2D$rownum) { 
  41.   global $v
  42.   for($i=0; $i<6; $i++){ 
  43.     $val = $sourceArr2D[$rownum][$i]; 
  44.     if( in_array($rownum...$val$v) ){ 
  45.       continue
  46.     } 
  47.     if( in_array($val,$sourceArr2D[$rownum-1]) && in_array($val,$sourceArr2D[$rownum+1]) ){ 
  48.       array_push($v, ($rownum-1)...$val$rownum...$val, ($rownum+1)...$val); 
  49.       $tmp = $rownum + 2; 
  50.       while( ($tmp < sizeof($sourceArr2D)) && in_array($val$sourceArr2D[$tmp]) ){ 
  51.         array_push($v$tmp...$val); 
  52.         $tmp++; 
  53.       } 
  54.     } 
  55.   } 
  56. // 判断/方向 
  57. $l = array();// 保存/方向上的搜寻结果 
  58. function check_l() { 
  59. // 判断方向 
  60. $r = array();// 保存方向上的搜寻结果 
  61. function check_r() { 
  62. // 结束定义,开始应用 
  63. checkAll($data); 
  64. echo 
  65. //水平方向上的找寻: 
  66. print_r($h); 
  67. echo 
  68. //竖直方向上的找寻: 
  69. print_r($v); 
  70. echo 
  71. //方向上的找寻: 
  72. print_r($l); 
  73. echo 
  74. //方向上的找寻: 
  75. print_r($r); 

希望本文所述对大家的php程序设计有所帮助。

Tags: php数组比较 php查找连续数

分享到: