利用C语言实现N皇后

3 篇文章 1 订阅
3 篇文章 0 订阅
本文介绍了一个使用C语言实现八皇后问题的程序,通过回溯算法寻找所有可能的解决方案。程序包含三个关键函数:Check()用于判断皇后位置的合法性,Output()输出解,NQueen()实现递归的回溯搜索。代码详细展示了如何在棋盘上避免皇后互相攻击,最终找到所有解并输出。
摘要由CSDN通过智能技术生成

 

内容:

在n*n格的国际象棋棋盘上,安放n个皇后,要求,没有一个皇后能够“吃掉”任何其他皇后,即任意两个皇后不能处于同一行、同一列或同一对角线上,这样的格局成为一个解。写出一个程序可以求出所有解。

步骤

1.算法分析

程序中需要的三个重要函数:

        函数check()用来判断皇后所放的位置(row,column)是否可行;

        函数output()用来输出可行解,即输出棋盘;

        函数Nqueen()采用递归算法实现在row行放置皇后。

        对于八皇后问题的求解可采用回溯算法,从上至下依次在每一行放置皇后,进行探索,若在某一行的任意一列放置皇后均不能满足要求,则不能再向下搜索,而进行回溯,回溯至有其他列可以放置皇后的一行,再向下进行搜索,直至搜索至最后一行,找到可行解,输出结果。

2.代码

#include<stdio.h>
#include<stdlib.h>
typedef int boolean;
#define true 1
#define false 0
int num = 0;/*解数目*/
int n;
char m[100][100] = { '*' };/*m[100][100] 表示棋盘,初始为*,表示未放置皇后*/
/*对于键盘前row-1行已放置好皇后*/
/*检查在第row行、第column行放置一枚皇后是否可行*/
boolean Check(int row, int column)
{
	int i, j;
	if (row == 1) return true;
	for (i = 0; i <= row - 2; i++)/*纵向只能有一枚皇后*/
	{
		if (m[i][column - 1] == 'Q')return false;
	}	
	/*左上至右下只能有一枚皇后*/
	i = row - 2;
	j = i - (row - column);
	while (i >= 0 && j >= 0)
	{
		if (m[i][j] == 'Q')return false;
		i--;
		j--;
	}
	/*右上至左下只能有一枚皇后*/
	i = row - 2;
	j = row + column - i - 2;
	while (i >= 0 && j <= 7)
	{
		if (m[i][j] == 'Q')return false;
		i--;
		j++;
	}
	return true;
}
void Output()/*当已放置n枚皇后,为可行解时,输出棋盘*/
{
	int i, j;
	num++;
	printf("可行解 %d:\n", num);
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < n; j++)
		{
			printf("%c", m[i][j]);
		}
		printf("\n");
	}
}
/*采用递归函数实现n皇后回溯算法*/
/*该函数求解当棋盘前row-1行已放置好皇后,在第row行放置皇后*/
void NQueen(int row)
{
	int j;
	for (j = 0; j < n; j++)/*考虑在第row行的各列放置皇后*/
	{
		m[row - 1][j] = 'Q';/*在其中一列放置皇后*/
		if (Check(row, j + 1) == true)/*检查在该列放置皇后是否可行*/
		{
			if (row == n)Output();/*若该列克放置皇后,且该列为最后一列,则找到一可行解,输出*/
			else NQueen(row + 1);/*若该列可放置皇后,则向下一行继续搜索、求解*/
		 /*取出该列的皇后,进行回溯,在其他列放置皇后*/
		}
		m[row - 1][j] = '*';

	}
}
/*主函数*/
void main()
{
	printf("100皇后以后无法运算\n");
	printf("请输入需要的皇后数;");
	scanf_s("%d", &n);
	if (n <= 100) {
		NQueen(1);/*求解n皇后问题*/
	}
	else
		printf("无法运算!!!!");
}

3.流程图

4.效果图

 

 

 

 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白日懵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值