使用回溯法来解决n皇后问题

本文通过回溯法解决N皇后问题,实现了一种算法来计算N×N棋盘上放置N个皇后的方法总数,并确保皇后间不互相攻击。文中详细介绍了代码实现过程及调试经验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

在一个N*N的棋盘上放置N个皇后,使得这N个皇后不能相互攻击,共有多少种不同的放置方法?


#include <stdio.h>
#include <stdlib.h>
#include <memory.h>
#include <math.h>

int * X = NULL;
int solutionCounts = 0;

//确定第k个皇后是不是能在第X[k]列上
bool Place(int k)
{
	int i = 1;
	while(i<k)
	{
		if(X[i] == X[k] || abs(X[i] - X[k]) == abs(i - k))
		{
			return false ;
		}
		i++;
	}
	return true;
}

void Print(int * X, int n)
{
	printf("第%d种方案如下:\n", solutionCounts);
	for(int i = 1; i<=n; i++)
	{
		printf("第%d个皇后的位置为:%d行%d列\n", i, i, X[i]);
	}
}

//其实是按一颗动态树来采用回溯法解决
void NQueens(int n)
{
	int k = 1;
	while(k>0)
	{
		//先找准第k个皇后的位置
		X[k] = X[k]+1;
		while(X[k]<=n && Place(k) == false)
		{
			X[k] += 1;	//转至下一列寻找合适的位置
		}
		//然后发现如果这个皇后还可以有下一个皇后摆的位置的话就继续向下找下一个皇后的位置
		if(X[k] <= n)
		{
			if(k==n) //说明所有的皇后的位置都已经确定了
			{
				solutionCounts++;
				Print(X, n);
			}
			else
			{
				k += 1;//向下找下一个皇后的位置
				X[k] = 0;
			}
		}
		else //说明这个皇后的这条路径已经走到头了
			k -= 1;
	}
}

void main()
{
	int n = 0;
	puts("please input the number of queens:");
	scanf("%d",&n);
	int *columns = (int *)malloc(n*sizeof(int));
	memset((void *)columns, 0, n*sizeof(int));
	X = columns;
	NQueens(n);
}

碰到的问题:

1、还是不能根据思路很好的转化为代码;

2、解决了一个在Visaul Studio2008上边出现的一个错误:“没有找到MSVCR90D.dll”,解决方法为:

       a,选择 菜单 Project -> 工程 Properties ,或者按 ALT+F7.打开 当前工程的 PropertyPages属性窗口,选择 Configuration Properties->Manifest Tool;在右边窗口中      设置Use FAT32 Work-around 项为 Yes.单击确定退出.

       b,Rebuild工程,运行一切正常.


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值