八皇后

转载:http://zhedahht.blog.163.com/blog/static/2541117420114331616329


   解决这个问题通常需要用递归,而递归对编程能力的要求比较高。因此有不少面试官青睐这个题目,用来考察应聘者的分析复杂问题的能力以及编程的能力。

   由于八个皇后的任意两个不能处在同一行,那么肯定是每一个皇后占据一行。于是我们可以定义一个数组columnIndex[8],数组中第i个数字表示位于第i行的皇后的列号。先把columnIndex的八个数字分别用0-7初始化,接下来要做的事情就是对数组columnIndex做全排列。由于我们是用不同的数字初始化数组中的数字,因此任意两个皇后肯定不同列。我们只需要判断得到的每个排列对应的八个皇后是不是在同一对角斜线上,也就是数组的两个下标i和j,是不是i-j==columnIndex[i]-columnIndex[j]或者j-i==columnIndex[i]-columnIndex[j]。

#include<iostream>

using namespace std;


int g_number = 0;

void printQueen(int columnIndex[], int length)
{
	printf("Solution %d\n", g_number);

	for(int i = 0; i < length; i++)
		printf("%d\t", columnIndex[i]);

	printf("\n");
}

bool check(int columnIndex[], int length)
{
	for(int i = 0; i < length; i++)
	{
		for(int j = i + 1; j < length; j++)
		{
			if(i - j == columnIndex[i] - columnIndex[j]
			|| i - j == columnIndex[i] - columnIndex[j])
				return false;
		}
	}

	return true;
}

void permutation(int columnIndex[], int length, int index)
{
	if(index == length)
	{
		if(check(columnIndex, length))
		{
			g_number++;
			printQueen(columnIndex, length);
		}
	}
	else
	{
		for(int i = index; i < length; i++)
		{
			int temp = columnIndex[index];
			columnIndex[index] = columnIndex[i];
			columnIndex[i] = temp;

			permutation(columnIndex, length, index + 1);

			temp = columnIndex[index];
			columnIndex[index] = columnIndex[i];
			columnIndex[i] = temp;
		}
	}
}

void eightQueen()
{
	const int queens = 8;
	int columnIndex[queens];
	for(int i = 0; i < queens; i++)
	{
		columnIndex[i] = i;
	}

	permutation(columnIndex, queens, 0);
}

int main()
{
	eightQueen();

	return 0;
}



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值