题解 | #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皇后#
全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
5578次浏览 54人参与
# 百度工作体验 #
316398次浏览 2233人参与
# 米连集团26产品管培生项目 #
7775次浏览 236人参与
# 沪漂/北漂你觉得哪个更苦? #
1926次浏览 46人参与
# 离家近房租贵VS离家远但房租低,怎么选 #
16967次浏览 137人参与
# 春招至今,你的战绩如何? #
17075次浏览 154人参与
# 巨人网络春招 #
11609次浏览 232人参与
# 你的实习产出是真实的还是包装的? #
3726次浏览 61人参与
# HR最不可信的一句话是__ #
1230次浏览 34人参与
# AI面会问哪些问题? #
1128次浏览 30人参与
# 你做过最难的笔试是哪家公司 #
1486次浏览 24人参与
# AI时代,哪个岗位还有“活路” #
3206次浏览 56人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
153013次浏览 889人参与
# 简历第一个项目做什么 #
32303次浏览 374人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
8085次浏览 44人参与
# 简历中的项目经历要怎么写? #
311420次浏览 4290人参与
# XX请雇我工作 #
51172次浏览 172人参与
# 投格力的你,拿到offer了吗? #
178477次浏览 891人参与
# 你最满意的offer薪资是哪家公司? #
77061次浏览 375人参与
# AI时代,哪些岗位最容易被淘汰 #
65158次浏览 923人参与
# 秋招白月光 #
731903次浏览 5441人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187733次浏览 1123人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务