题解 | #N皇后问题#
N皇后问题
https://www.nowcoder.com/practice/c76408782512486d91eea181107293b6
<?php
function ceshi($qipan,$n,$row,$col){//这是判断一个棋子放在指定位置合理性的函数
//检测同列有没有棋子 如果有 棋子放在这个位置不合理 返回false
for($i=0;$i<$n;$i++){
if ($qipan[$i][$col]=="Q")return false;
}
//检测左上方45度对角有没有棋子 如果有 棋子放在这个位置不合理 返回false
for($i=1,$j=1;$i<=$col&&$j<=$row;$i++,$j++){
if ($qipan[$row-$i][$col-$j]=="Q")return false;
}
//检测右上方45度对角有没有棋子 如果有 棋子放在这个位置不合理 返回false
for($i=1,$j=1;$i<=$row&&($col+$j)<$n;$i++,$j++){
if ($qipan[$row-$i][$col+$j]=="Q")return false;
}
//不检测同行棋子合法性是因为放了个棋子之后会马上换一行 所不需要判断同行 不检测下方是为了空间时间复杂度优化 因为是从第一行步进向下的所以不需要检测下方的 上方所有判断都合规 证明这个落子是合规的 棋子可以放在这里 返回true
return true;
}
function digui($qipan,$n,$row,$shuliang){//这是棋盘递归方法
if($row>=$n){
//如果递归到了最后一排 代表整个棋盘都递归完了
$shuliang++;
//加一个可以摆放方式技术
return $shuliang;
//返回计数给上一层
}
for($i=0;$i<$n;$i++){
//从第一列开始从左到右
if(ceshi($qipan,$n,$row,$i)){//如果棋子放在这里合理的话
//将棋子放在这里
$qipan[$row][$i]='Q';
//递归自己 将行数加一 检测下一排棋子应该放在哪
$shuliang=digui($qipan,$n,$row+1,$shuliang);
//回溯了后 把之前放在这里的棋子拿起啦
$qipan[$row][$i]='.';
}
}
//返回计数给上一层
return $shuliang;
}
function Nqueen( $n )
{
//创建一个数组
$qipan=[];
//按照棋盘的长宽创建一个棋盘
$qipan=array_pad($qipan,$n,array_pad($qipan,$n,'.'));
//从棋盘的第一行第一列开始递归查询
$shuliang=digui($qipan,$n,0,0);
//返回计数
return $shuliang;
}
#图像算法##解题##n皇后#
传音控股公司福利 344人发布

