N皇后问题(超详细c++代码)
本文介绍了如何使用递归和回溯方法解决N皇后问题,通过定义判断函数检查行、列和斜线冲突,然后利用深度优先搜索策略寻找解决方案,最后计算满足条件的皇后摆放数量。
问题:N皇后问题是指在N*N的棋盘上摆放N个皇后,使得任意两个皇后都不在同一行、同一列或者同一斜线上,求满足这种摆放的解为多少个
解题思路:
(1)定义判断函数: 判断是否可以放置皇后: 不同行(第几个皇后已经表示第几行了,不用判断);不同列(即将放置的皇后与之前所有皇后所在列不同);不同斜线(即将放置的皇后与之前所有皇后练成线的斜率不为±1)
(2)定义递归的回溯函数,并调用判断函数:
若在该行遍历完n之前能够找到位置放置皇后,则向下一行递归,若没有位置,则向上回溯。如果棋盘所有行列寻找完毕,则解的个数+1
c++代码如下:
//N皇后问题 #include<bits/stdc++.h> int n; int ans; int x[15];//x[a]=b表示第a个皇后在第a行,第b列 using namespace std; int PD(int a){//对放置的第a个皇后进行判断是否可以放置 for(int i=1;i<a;i++){ if(abs(x[i]-x[a])==abs(i-a)){ return 0;//如果在同一斜线就返回0 } else if(x[i]==x[a]){ return 0;//如果在同一列就返回0 } } //如果以上都没有就返回1 return 1; } //深度优先搜索 void DFS(int a){//对第a个皇后进行放置 if(a>n){ ans++;//检查是否放置了第n个皇后,如果已经放了n个皇后就ans加1 return; } else{ for(int i=1;i<=n;i++){//对第a行,1到n列 全部进行放置 x[a]=i; if(PD(a)){//如果可以放置就对下一个皇后进行放置 DFS(a+1); } else{//不能放就看下一列 continue; } } } } int main(){ cin>>n; DFS(1);//从第一个皇后开始放置 cout<<ans<<endl; return 0; }
//N皇后问题
#include<bits/stdc++.h>
int n;
int ans;
int x[15];//x[a]=b表示第a个皇后在第a行,第b列
using namespace std;
int PD(int a){//对放置的第a个皇后进行判断是否可以放置
for(int i=1;i<a;i++){
if(abs(x[i]-x[a])==abs(i-a)){
return 0;//如果在同一斜线就返回0
}
else if(x[i]==x[a]){
return 0;//如果在同一列就返回0
}
}
//如果以上都没有就返回1
return 1;
}
//深度优先搜索
void DFS(int a){//对第a个皇后进行放置
if(a>n){
ans++;//检查是否放置了第n个皇后,如果已经放了n个皇后就ans加1
return;
}
else{
for(int i=1;i<=n;i++){//对第a行,1到n列 全部进行放置
x[a]=i;
if(PD(a)){//如果可以放置就对下一个皇后进行放置
DFS(a+1);
}
else{//不能放就看下一列
continue;
}
}
}
}
int main(){
cin>>n;
DFS(1);//从第一个皇后开始放置
cout<<ans<<endl;
return 0;
}
- 海报
免责声明:本站除原创代码外的资源均收集于网络,不保证代码的完整性和可用性,只做学习和交流使用,版权归原作者所有,请在下载后24小时之内自觉删除。若作商业用途,请购买正版,由于未及时购买正版授权发生的侵权行为,与本站无关。本站的内容如果侵犯了您的权益,请及时告知我们,我们即刻处理!
少儿编程课程 儿童编程教育 编程启蒙班 青少年编程培训 Scratch编程学习 Python少儿编程 机器人编程教育 编程思维训练 编程游戏化教学 在线少儿编程平台 儿童编程软件推荐 编程竞赛准备 编程兴趣班 逻辑思维与编程 少儿编程教材 编程与STEM教育 编程技能培养 编程语言入门(如:JavaScript少儿版) 家长如何选择少儿编程课 编程对孩子未来的影响 编程项目实践 编程与创造力培养 编程思维在日常生活中的应用 编程教育专家观点 编程教育趋势分析 少儿编程社区 编程夏令营 编程冬令营 编程学习路线图 编程证书考试 少儿编程启蒙 儿童图形化编程(如Scratch编程) 青少年Python编程 编程基础班(针对小学生) 编程进阶课程(适合高年级学生) 机器人编程工作坊 AI启蒙编程课 逻辑思维编程游戏 编程与数学能力提升 编程思维训练营 编程解决问题的能力培养 在线互动编程课堂 编程项目实战演练 编程创意工坊 编程教育APP推荐 编程教育论坛与社区 编程兴趣小组 编程竞赛辅导 编程证书考试准备 编程教育政策解读 编程教育家长指南 编程与跨学科学习(STEM/STEAM) 编程与创新能力培养 编程与未来职业规划 编程教育师资培训 编程教育研究成果分享 编程教育行业标准 编程教育市场动态 编程教育投资前景 编程教育公益项目
微点点-专业的知识付费平台 » N皇后问题(超详细c++代码)
少儿编程课程 儿童编程教育 编程启蒙班 青少年编程培训 Scratch编程学习 Python少儿编程 机器人编程教育 编程思维训练 编程游戏化教学 在线少儿编程平台 儿童编程软件推荐 编程竞赛准备 编程兴趣班 逻辑思维与编程 少儿编程教材 编程与STEM教育 编程技能培养 编程语言入门(如:JavaScript少儿版) 家长如何选择少儿编程课 编程对孩子未来的影响 编程项目实践 编程与创造力培养 编程思维在日常生活中的应用 编程教育专家观点 编程教育趋势分析 少儿编程社区 编程夏令营 编程冬令营 编程学习路线图 编程证书考试 少儿编程启蒙 儿童图形化编程(如Scratch编程) 青少年Python编程 编程基础班(针对小学生) 编程进阶课程(适合高年级学生) 机器人编程工作坊 AI启蒙编程课 逻辑思维编程游戏 编程与数学能力提升 编程思维训练营 编程解决问题的能力培养 在线互动编程课堂 编程项目实战演练 编程创意工坊 编程教育APP推荐 编程教育论坛与社区 编程兴趣小组 编程竞赛辅导 编程证书考试准备 编程教育政策解读 编程教育家长指南 编程与跨学科学习(STEM/STEAM) 编程与创新能力培养 编程与未来职业规划 编程教育师资培训 编程教育研究成果分享 编程教育行业标准 编程教育市场动态 编程教育投资前景 编程教育公益项目
微点点-专业的知识付费平台 » N皇后问题(超详细c++代码)