题解 | #八皇后#

八皇后

https://www.nowcoder.com/practice/fbf428ecb0574236a2a0295e1fa854cb

#include <iostream>
#include <vector>
using namespace std;
//同一斜对角线皇后行差值绝对值等于列差值绝对值
vector<int> pos(9);//八个皇后的列位置,下标代表第几行皇后
vector<string> allStr;//dfs的过程确保了自动有序
bool judge(int row,int& choice){
    for(int i=1;i<row;i++){//遍历前row-1个皇后的列位置
        if(pos[i]==choice) return false;//同列
        if(abs(row-i)==abs(choice-pos[i])) return false;//左上对角线,右上对角线(不可能有其他情况)
    }
    return true;
}
void dfs(int row,string& str){
    if(row>8){
        allStr.emplace_back(str);
        return;
    }
    for(int col=1;col<=8;col++){
        if(judge(row,col)){
            pos[row] = col;
            str+=(col+'0');
            dfs(row+1,str);
            str.erase(str.end()-1);
        }
    }
    return;
}
int main() {
    int n;
    string str="";
    dfs(1,str);
    while (cin >> n) {
        cout<<allStr[n-1]<<endl;
    }
}

全部评论

相关推荐

小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 14:00
不想多说了,什么逆天HR,还要教我礼貌😂
机械打工仔:这不纯傻卵吗,他还操心上别人老板了
投递BOSS直聘等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务