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

相关推荐

03-15 10:59
已编辑
美团_后端开发(实习员工)
爱写代码的菜code...:哎,自己当时拿到字节offer的时候也在感叹终于拿到了,自己当时最想去的企业就是字节,结果还是阴差阳错去了鹅厂。祝uu一切顺利!!!
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
4471次浏览 48人参与
# 离家近房租贵VS离家远但房租低,怎么选 #
16917次浏览 137人参与
# 米连集团26产品管培生项目 #
7385次浏览 226人参与
# 沪漂/北漂你觉得哪个更苦? #
1616次浏览 41人参与
# 你的实习产出是真实的还是包装的? #
3230次浏览 54人参与
# 春招至今,你的战绩如何? #
16140次浏览 146人参与
# 巨人网络春招 #
11543次浏览 229人参与
# HR最不可信的一句话是__ #
1107次浏览 32人参与
# AI面会问哪些问题? #
971次浏览 24人参与
# 你做过最难的笔试是哪家公司 #
1306次浏览 23人参与
# AI时代,哪个岗位还有“活路” #
2930次浏览 53人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152945次浏览 889人参与
# 简历第一个项目做什么 #
32180次浏览 363人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
8029次浏览 43人参与
# XX请雇我工作 #
51164次浏览 171人参与
# 简历中的项目经历要怎么写? #
311119次浏览 4271人参与
# 投格力的你,拿到offer了吗? #
178382次浏览 891人参与
# 你最满意的offer薪资是哪家公司? #
77008次浏览 375人参与
# AI时代,哪些岗位最容易被淘汰 #
64856次浏览 893人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187635次浏览 1123人参与
# 你怎么看待AI面试 #
180882次浏览 1318人参与
# 正在春招的你,也参与了去年秋招吗? #
364407次浏览 2642人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务