m0_61849826 2021-11-11 15:16 采纳率: 100%
浏览 53
已结题

写了一个求解八皇后问题的问题代码


#include <iostream>
#include <cstring>

using namespace std;

int queen( int col[9],int start){    //数组的下标代表列,col[i]的值代表在该列放的皇后所在的行数.
    if(start == 9){
            for(int j = 1; j <9; j++)cout << col[j] ;
            cout << endl;
            return 0;//假如正常进行到第八列, 就输出数组;
        }
    for(int i =start; i <9; i ++){
        for(int k = 1; k <9; k++){
            bool flag = true;
            col[i] = k;//给第i列的第k行放上皇后;
            for(int j = 1; j < 9;j++){
                if (i == j || col[j] == 0) continue;//不与同一个格子、没有放皇后的格子;进行比较
                if(col[j] == col[i]|| i+col[i] == j + col[j] || i- col[i] == j-col[j]) {//检测是否有同行、同对角线的皇后
                        flag = false;col[i] = 0;break;/*如果有问题,flag输出false,跳出循环
                                                        如果没有,flag为true;尝试在下一列放置皇后*/
                    }
                }
            if(flag){
                if(!col[i]) return 0;//如果flag为true,而且在该列放置了皇后,就继续对下一列进行放置操作;如果未放置,说明此时无解,跳出本层递归;
                queen(col,start+1);
            }
        }
    }
}


int main(){
 int queens[9] = {0};

 queen(queens,1);
}

以上,输出了很多很多个数字..

  • 写回答

3条回答 默认 最新

  • CSDN专家-link 2021-11-11 15:22
    关注

    主要的问题是你已经用递归了,那么for(int i=start;i<9;i++)这个循环就不需要了,递归本身就相当于这个循环
    把这层循环去掉,同时把i都改为start

    #include <iostream>
    #include <cstring>
    using namespace std;
    int queen( int col[9],int start){    //数组的下标代表列,col[i]的值代表在该列放的皇后所在的行数.
        if(start == 9){
                for(int j = 1; j <9; j++)cout << col[j] ;
                cout << endl;
                return 0;//假如正常进行到第八列, 就输出数组;
            }
     //   for(int i =start; i <9; i ++){
            for(int k = 1; k <9; k++){
                bool flag = true;
                col[start] = k;//给第i列的第k行放上皇后;
                for(int j = 1; j < 9;j++){
                    if (start == j || col[j] == 0) continue;//不与同一个格子、没有放皇后的格子;进行比较
                    if(col[j] == col[start]|| start+col[start] == j + col[j] || start- col[start] == j-col[j]) {//检测是否有同行、同对角线的皇后
                            flag = false;col[start] = 0;break;/*如果有问题,flag输出false,跳出循环
                                                            如果没有,flag为true;尝试在下一列放置皇后*/
                        }
                    }
                if(flag){
                    if(!col[start]) return 0;//如果flag为true,而且在该列放置了皇后,就继续对下一列进行放置操作;如果未放置,说明此时无解,跳出本层递归;
                    queen(col,start+1);
                }
     //       }
        }
    }
     
    int main(){
     int queens[9] = {0};
     queen(queens,1);
    return 0;
    }
    
    

    img

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

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 多尺度特征图提取和融合
  • ¥15 微信小程序:渲染收货地址时页面不显示
  • ¥20 win7 64位DirectShow提示初始化失败如何解决?
  • ¥20 小规模孤立词识别系统设计
  • ¥15 关于Java对接海康威视车牌识别一体机SDK是否需要固定外网的IP?
  • ¥15 Linux扩容时,格式化卡住了:vgdispaly查看卷组信息,没有输出
  • ¥18 关于#ubuntu#的问题:使用背景-工作职责内有七八台ubuntu系统的电脑,平时需要互相调取资料,想实现把这几台电脑用交换机组成一个局域网,来实现指定文件夹的互相调取和写入
  • ¥20 求一个简易射频信号综测仪
  • ¥15 esp8266 tally灯 接收端改为发射端
  • ¥30 Labview代码调用access 数据库,相同代码其中一个调用不出来是为什么