#include <iostream>
#include<cmath>
using namespace std;
#define N 8
static int count = 1;
int matrix[N + 1][N + 1] = {0};
// matrix[0][j]为空,matrix[i][0]中放第i行的皇后的列坐标(从1开始记)
bool IsLegal(const int &i, const int &j)
{
// 判断前面的i-1个棋子(坐标是matrix[m][n])与matrix[i][j]是否冲突,i为1时合法
for (int m = 1; m <= i - 1; ++m) {
int n = matrix[m][0];
if ( n == j || abs(i - m) == abs(j - n) ) //abs(i-m)==abs(j-n)设计的很巧妙
return false;
}
return true;
}
void Print(void) //打印函数,都明白,不用过多的解释
{
printf("Case %d:\n", count++);
for (int i = 1; i <= N; i++) {
for (int j = 1; j <= N; j++) {
matrix[i][j] == 1 ? printf("%c ", 5) : printf(". ");
}
cout << endl;
}
cout << endl;
}
void Trial(const int &i) //最主要的函数,明白此函数就明白了八皇后问题的解法。
{
// 进入本函数时,在N*N的棋盘前i-1行已放置了互不攻击的i-1个棋子
// 现从第i行起继续为后续棋子选择合适位置
if (i > N) // 输出当前的合法布局
Print();
else
for (int j = 1; j <= N; ++j) {
matrix[i][j] = 1;
if ( IsLegal(i, j) ) {
matrix[i][0] = j;
Trial(i + 1);
}
matrix[i][j] = 0;
}
}
int main(void)
{
Trial(1);
return 0;
}
//个人认为这个代码更好理解一点
|