「JoyOI1080」N皇后
这是菜鸡的我第一次写这类题目:
题意:就是在N*N的棋盘上,每一行,每一列,所有的对角线都只能有一个棋子。
先分析:假若N=4;
则为其中的一种答案。要输出左右的解,肯定要枚举出所有的解。那么非常自然的想到递归!
根据题意,每一步棋子都满足,在一行,一列,两个对角线。那么怎么解决呢?
总体递归思路,肯定是以一行为处理单位的啦。每一行总从左到右是判断是否这个棋子可以判断。
不相邻行的两个棋子:
在这里,我们先解决不为相邻行时,两个棋子不同列不同对角线问题。
不同列:直接定义一个数组,比如b[ 1 ]=1就表示第1列已经摆了一个棋子了。那么后面的棋子直接判断就行了。
不同列:
很明显在出现这种情况之前一定会出现这种摆法:
所以根本不用担心这种情况的发生。
相邻行的两个棋子:
我们解决怎样判断同一列,在两个对角线中。
不同列:直接定义一个数组,比如b[ 1 ]=1就表示第1列已经摆了一个棋子了。那么后面的棋子直接判断就行了。
对角线一: 假设第一个点坐标为(x, y)那么,相邻行并且同对角线的下一个点的坐标是就是(x+1, y-1),对吧。是不是找到规律了。
x+y=(x+1)+(y-1) 这样就定义一个数组c[], 那么 c[x+y]=1就可以表示点(x, y)所在的这类这条对角线已经有一个棋子。
对角线二:这类对角线的上的点的坐标变化都是横纵坐标各自加1.这其实很好办,每个坐标都满足x-y+n=k,每一条对角线对应唯一的一
个k值.至于x,y谁在前谁在后都无所谓,关键是抵消加1这个操作。那么定义d[ x-y+n ]=1表示这个对角线已经有了一个棋子。
#include<iostream> using namespace std; int n, sum, a[15]; bool b[100], c[100], d[100]; void print(){ sum++; if (sum <= 3){ for (int i = 1; i <= n; ++i) { cout << a[i] << " \n"[(i != n ? 0 : 1)]; } } } void queen(int i) { for (int j = 1; j <= n; ++j) { if ((b[j] == 0) && (c[i + j] == 0) && (d[i - j+n] == 0)) { a[i] = j; b[j] = 1; c[i + j] = 1; d[i - j + n] = 1; if (i == n)print(); else queen(i + 1); b[j] = 0; c[i + j] = 0; d[i - j + n] = 0; } } } int main() { cin >> n; queen(1); cout << sum << endl; return 0; }
作者:ALINGMAOMAO
出处:https://www.cnblogs.com/ALINGMAOMAO/p/10008052.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探