📄 皇后问题递归求解.txt
字号:
#include<cstdlib>
#include<iostream>
using namespace std;
const int MAX = 8; //棋子数及其棋盘大小MAX*MAX
int board[MAX]; //存放结果
bool check_cross( int n)
{
//对从0到n个皇后进行检验
int i;
for( i =0;i < n;i++)
{
if(board[i] == board[n] || ((n-i) == abs(board[i]-board[n]))) //这里不要写错了
return 1; //说明有cross的情况存在
}
return 0;
}
void show_result()
{
int i =0;
for( i = 0; i < MAX; i++)
cout<<board[i]<<" ";
cout<<endl;
}
void put_chess( int n)
{
//对第n行放置一棵皇后.
int i;
for(i=0;i<MAX;i++) //循环试探
{
board[n] = i;
if(!check_cross(n))//如果符合规则,即没有皇后在同一直线上
{
if( n == MAX-1 )
show_result();
else
put_chess(n+1); //放下一颗棋子
}
}
}
void main()
{
put_chess(0);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -