题解 | #八皇后#

八皇后

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

#include <stdio.h>
#include <string.h>
int q[9][9]={0};
int ans=0;
char que[93][9];
int t[9]={0};
int Place(int i,int n){
    for(int j=1;j<n;j++){
            if(t[j]==i) return 0;
    }
    for(int j=1;j<n;j++){
        if((t[j]-j)==(i-n)||(t[j]+j)==(n+i))
            return 0;
    }
    return 1;
}
void queen(int n){
    if(n>8){
        ans++;
        for(int i=1;i<9;i++){
            que[ans][i]=t[i]+'0';
        }
        return;
    }
    else{
        for(int i=1;i<=8;i++){
            if(Place(i,n)){
                //printf("%d %d\n",n,i);
                q[n][i]=1;
                t[n]=i;
                queen(n+1);
            }
        }
    }
}
int main() {
    int x;
    //int i=0;
    //char q[93][9]={'\0'};
    
    queen(1);
    scanf("%d\n",&x);
        for(int i=1;i<=8;i++){
            printf("%c",que[x][i]);
        }
        printf("\n");
    //printf("%d\n",ans);
    /*for(int i=0;i<=ans;i++){
        for(int j=1;j<=8;j++){
            printf("%c ",que[i][j]);
        }
        printf("\n");
    }*/
}

全部评论

相关推荐

06-07 19:59
门头沟学院 C++
补药卡我啊😭:都快15年前的了还在11新特性
你的简历改到第几版了
点赞 评论 收藏
分享
牛客83700679...:简历抄别人的,然后再投,有反馈就是简历不行,没反馈就是学历不行,多投多改只要技术不差机会总会有的
点赞 评论 收藏
分享
06-27 18:53
门头沟学院 Java
这样才知道自己不适合搞代码,考公去咯
只爱喝白开水:我也发现不适合搞代码,打算转非技术方向了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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