八皇后问题(C语言)

了解题意

在一个8x8的棋盘上放置8个皇后,使得任何两个皇后都不能处于同一行、同一列或同一斜线上。问有多少种方法可以放置这8个皇后?

解决这个问题的目标是找到所有符合要求的皇后摆放方式,通常使用回溯算法来求解。回溯算法会尝试所有可能的摆放方式,一旦发现某个摆放方式会导致冲突(即两个皇后在同一行、同一列或同一斜线上),就立即回溯到上一步,尝试其他的摆放方式。

八皇后问题的解法有很多种,其中一个经典解法是使用递归和剪枝。在递归过程中,算法会尝试在每一行放置一个皇后,并检查是否与前面放置的皇后发生冲突。如果发生冲突,就回溯到上一行重新放置皇后。如果没有发生冲突,就将该摆放方式加入到结果集中。为了避免重复计算,可以使用一个数组来记录已经放置的皇后所在的行和列,以便在回溯时跳过已经计算过的摆放方式。


放置皇后的地方置为1,其余置为0.


代码如下(示例):

c 复制代码
#include <stdio.h>
int cnt=0;//解法个数
int qq[8][8]={0};
void cout_cheek(int aa[][8],int n){//输出二维数组
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			printf("%d ",aa[i][j]);
		}
		printf("\n");
	}
	printf("\n");
}

int notdanger(int qq[][8],int n,int k){//判断某位置是否安全
	for(int i=0;i<n;i++){
		if(qq[i][k]==1) return 0;//该列
	}
	for(int i=n,j=k;i>=0&&j>=0;i--,j--){//左上角
		if(qq[i][j]==1) return 0;
	}
	for(int i=n,j=k;i>=0&&j<8;i--,j++){//右上角
		if(qq[i][j]==1) return 0;
	}
	return 1;
}
void queen(int qq[][8],int n){
if(8==n){
		cnt++;
		printf("第%d种答案:\n",cnt);
		cout_cheek(qq,8);
	}else{
		for(int k=0;k<8;k++){
			if(notdanger(qq,n,k)){
				qq[n][k]=1;
				queen(qq,n+1);
				qq[n][k]=0;
			}
		}
	}
}
int main(){
	queen(qq,0);
	printf("cnt==%d\n",cnt);
	return 0;
}

递归和回溯是经典算法。


相关推荐
TDengine (老段)2 分钟前
TDengine 新功能 VARBINARY 数据类型
大数据·c语言·数据库·时序数据库·tdengine·涛思数据
pianmian13 小时前
贪心算法.
算法·贪心算法
chenziang14 小时前
leetcode hot 100 二叉搜索
数据结构·算法·leetcode
single5945 小时前
【c++笔试强训】(第四十五篇)
java·开发语言·数据结构·c++·算法
呆头鹅AI工作室6 小时前
基于特征工程(pca分析)、小波去噪以及数据增强,同时采用基于注意力机制的BiLSTM、随机森林、ARIMA模型进行序列数据预测
人工智能·深度学习·神经网络·算法·随机森林·回归
一勺汤6 小时前
YOLO11改进-注意力-引入自调制特征聚合模块SMFA
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·目标跟踪
每天写点bug7 小时前
【golang】map遍历注意事项
开发语言·算法·golang
程序员JerrySUN7 小时前
BitBake 执行流程深度解析:从理论到实践
linux·开发语言·嵌入式硬件·算法·架构
王老师青少年编程7 小时前
gesp(二级)(16)洛谷:B4037:[GESP202409 二级] 小杨的 N 字矩阵
数据结构·c++·算法·gesp·csp·信奥赛
robin_suli8 小时前
动态规划子序列问题系列一>等差序列划分II
算法·动态规划