// 埋雷 一维数组表示
function lei($m, $n, $k){
$arr = array();// 雷阵 该位置是否有雷1有0无
$arr_lei_num = array(); // 该位置周边雷的个数
$total = $total2 = $m*$n;
for($i=0; $i<$total; $i++){
$arr[$i]=0;
if( $k>0 && ($total2 <= $k || mt_rand(0,$total2) < $k)){
$arr[$i]=1;
$k--;
}
$total2--;
if(empty($arr[$i])){
continue;
}
foreach(array($i+1, $i-1, $i+$n,$i+$n-1,$i+$n+1,$i-$n,$i-$n+1,$i-$n-1) as $h){
$abs = abs($i%$m - $h%$n);
if($h>=0 && $h<$total && $abs<=1){ // 边界检查
if(!isset($arr_lei_num[$h])){
$arr_lei_num[$h] = 0;
}
$arr_lei_num[$h]++;
}
}
}
return array('lei'=>$arr, 'num'=>$arr_lei_num);
}
有疑问加站长微信联系(非本文作者))