回溯法之N皇后问题——C++代码-微点点-专业的知识付费平台

回溯法之N皇后问题——C++代码

问题:N皇后问题是指在N*N的棋盘上摆放N个皇后,使得任意两个皇后都不在同一行、同一列或者同一斜线上,求满足这种摆放的解为多少个
解题思路:
(1)定义判断函数:不同行(每行只放置一个皇后);不同列(放置前进行遍历,即将放置的皇后与之前所有皇后所在列不同);不同斜线(放置前进行遍历,即将放置的皇后与之前所有皇后练成线的斜率不为±1)
(2)定义递归的回溯函数,并调用判断函数。若在该行遍历完n之前能够找到位置放置皇后,则向下一行递归,若没有位置,则向上回溯。如果棋盘所有行列寻找完毕,则解的个数+1

#include <iostream>
#include <cmath>
using namespace std;

#define max 50
int x[max + 1];//第i行的皇后放在第x[i]列上

int n;//棋盘宽度以及皇后数量
int sum=0;//计算解的数量


//即将放入的皇后坐标为(row,col),判断是否能够放置
bool Place(int row, int col) {   
    for (int i = 1; i < row; i++)  //比较之前row -1行已经放置的皇后
    {
        if (col == x[i] || abs(row - i) == abs(col - x[i]))  //判断即将放的皇后与已经存在的皇后们是否处于同一列或同一斜线
            return false;
    }
    return true;
}

//递归的回溯函数,若满足条件则往下递归,若不满足条件,则往前回溯
void Backtrack(int t,int n) {
    if (t == n+1)  //成功将全部棋盘遍历了一次,形成了一个解
        sum++;
    else {
        //若这一行遍历到n仍不能放置皇后,则向前回溯
        for (int i = 1; i <= n; i++) {
            x[t] = i;
            if (Place(t, x[t]))//判断是否能放置皇后
                Backtrack(t + 1, n);//若这一行能放置皇后,则向下一行进行递归
        }
    }
}

int main()
{
    cout << "请输入皇后的数量: ";
    cin >> n;
    Backtrack(1,n);
    cout << "解的个数为: " << sum<<endl;

    return 0;
}

#include <iostream>
#include <cmath>
using namespace std;

#define max 50
int x[max + 1];//第i行的皇后放在第x[i]列上

int n;//棋盘宽度以及皇后数量
int sum=0;//计算解的数量


//即将放入的皇后坐标为(row,col),判断是否能够放置
bool Place(int row, int col) {   
    for (int i = 1; i < row; i++)  //比较之前row -1行已经放置的皇后
    {
        if (col == x[i] || abs(row - i) == abs(col - x[i]))  //判断即将放的皇后与已经存在的皇后们是否处于同一列或同一斜线
            return false;
    }
    return true;
}

//递归的回溯函数,若满足条件则往下递归,若不满足条件,则往前回溯
void Backtrack(int t,int n) {
    if (t == n+1)  //成功将全部棋盘遍历了一次,形成了一个解
        sum++;
    else {
        //若这一行遍历到n仍不能放置皇后,则向前回溯
        for (int i = 1; i <= n; i++) {
            x[t] = i;
            if (Place(t, x[t]))//判断是否能放置皇后
                Backtrack(t + 1, n);//若这一行能放置皇后,则向下一行进行递归
        }
    }
}

int main()
{
    cout << "请输入皇后的数量: ";
    cin >> n;
    Backtrack(1,n);
    cout << "解的个数为: " << sum<<endl;

    return 0;
}

 

  • 海报
海报图正在生成中...
免责声明:本站除原创代码外的资源均收集于网络,不保证代码的完整性和可用性,只做学习和交流使用,版权归原作者所有,请在下载后24小时之内自觉删除。若作商业用途,请购买正版,由于未及时购买正版授权发生的侵权行为,与本站无关。本站的内容如果侵犯了您的权益,请及时告知我们,我们即刻处理!
少儿编程课程 儿童编程教育 编程启蒙班 青少年编程培训 Scratch编程学习 Python少儿编程 机器人编程教育 编程思维训练 编程游戏化教学 在线少儿编程平台 儿童编程软件推荐 编程竞赛准备 编程兴趣班 逻辑思维与编程 少儿编程教材 编程与STEM教育 编程技能培养 编程语言入门(如:JavaScript少儿版) 家长如何选择少儿编程课 编程对孩子未来的影响 编程项目实践 编程与创造力培养 编程思维在日常生活中的应用 编程教育专家观点 编程教育趋势分析 少儿编程社区 编程夏令营 编程冬令营 编程学习路线图 编程证书考试 少儿编程启蒙 儿童图形化编程(如Scratch编程) 青少年Python编程 编程基础班(针对小学生) 编程进阶课程(适合高年级学生) 机器人编程工作坊 AI启蒙编程课 逻辑思维编程游戏 编程与数学能力提升 编程思维训练营 编程解决问题的能力培养 在线互动编程课堂 编程项目实战演练 编程创意工坊 编程教育APP推荐 编程教育论坛与社区 编程兴趣小组 编程竞赛辅导 编程证书考试准备 编程教育政策解读 编程教育家长指南 编程与跨学科学习(STEM/STEAM) 编程与创新能力培养 编程与未来职业规划 编程教育师资培训 编程教育研究成果分享 编程教育行业标准 编程教育市场动态 编程教育投资前景 编程教育公益项目
微点点-专业的知识付费平台 » 回溯法之N皇后问题——C++代码

发表回复

提供最优质的资源集合

立即查看 了解详情

欢迎给我们留言 +