「已注销」 2021-10-27 15:33 采纳率: 100%
浏览 19
已结题

8皇后问题如何输出坐标?

C语言的8皇后问题,怎么用代码输出坐标?代码如下,怎么改?


#include<stdio.h>

#define line 8

void queen(int i,int j);

int check(int i,int j);

int chess[line][line];

int cas=0;
int xx,yy;


int main(){

queen(0,0);

printf("%d\n",cas);

return 0;

}



void queen(int i,int j){

if(j>=line){

return ;

}



if(check(i,j)==1){//如果能放

 chess[i][j]=1;//放皇后

 if(i==line-1){//如果是最后一行,记录情况

 cas++;
    /*下面是输出每种棋盘结果,供测试    
     for (xx=0;xx<8;xx++) 

         for(yy=0;yy<8;yy++){ 

        printf("%d",chess[xx][yy]); 

        if(yy==7) 

            printf("\n"); 

        } 

     printf("\n");     

    上面是输出结果*/

}

else{

queen(i+1,0);//不是最后一行就分析下一行

 }

}

chess[i][j]=0;//如果此位置不能放,就置空(0),判断旁边的格子。

 //如果此位置能放,走到这里就意味着上面的代码全部执行了,把皇后拿走(置零),再讨论其他情况,拿旁边位置试探。

 queen(i,j+1);

}





int check(int i,int j){

int k;



for(k=0;k<line;k++){

if(chess[i][k]==1) return 0;//0=不能放

 }

for(k=0;k<line;k++){

if(chess[k][j]==1) return 0;

}

for(k=-line;k<=line;k++){//两对角线

 if(i+k>=0&&i+k<line&&j+k>=0&&j+k<line)//从左上到右下对角线

 if(chess[i+k][j+k]==1) return 0;



if(i-k>=0&&i-k<line&&j+k>=0&&j+k<line)//从左下到右上对角线

 if(chess[i-k][j+k]==1) return 0;

}

return 1;

}
  • 写回答

2条回答 默认 最新

  • 关注
    
     
    #include<stdio.h>
    #define line 8
    void queen(int i,int j);
    int check(int i,int j);
    int chess[line][line];
    int cas=0;
    int xx,yy;
     
    int main(){
    queen(0,0);
    printf("%d\n",cas);
    return 0;
    }
     
    void queen(int i,int j){
    if(j>=line){
    return ;
    }
     
    if(check(i,j)==1){//如果能放
     chess[i][j]=1;//放皇后
     if(i==line-1){//如果是最后一行,记录情况
     cas++;
           
         for (xx=0;xx<8;xx++) 
             for(yy=0;yy<8;yy++){ 
            printf("%d",chess[xx][yy]); 
            if(yy==7) 
                printf("\n"); 
            } 
         printf("\n");    
    }
    else{
    queen(i+1,0);//不是最后一行就分析下一行
     }
    }
    chess[i][j]=0;//如果此位置不能放,就置空(0),判断旁边的格子。
     //如果此位置能放,走到这里就意味着上面的代码全部执行了,把皇后拿走(置零),再讨论其他情况,拿旁边位置试探。
     queen(i,j+1);
    }
     
     
    int check(int i,int j){
    int k;
     
    for(k=0;k<line;k++){
    if(chess[i][k]==1) return 0;//0=不能放
     }
    for(k=0;k<line;k++){
    if(chess[k][j]==1) return 0;
    }
    for(k=-line;k<=line;k++){//两对角线
     if(i+k>=0&&i+k<line&&j+k>=0&&j+k<line)//从左上到右下对角线
     if(chess[i+k][j+k]==1) return 0;
     
    if(i-k>=0&&i-k<line&&j+k>=0&&j+k<line)//从左下到右上对角线
     if(chess[i-k][j+k]==1) return 0;
    }
    return 1;
    }
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月27日
  • 已采纳回答 11月19日
  • 创建了问题 10月27日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度