手机
当前位置:查字典教程网 >编程开发 >C语言 >八皇后问题实现代码分享
八皇后问题实现代码分享
摘要:main.cpp复制代码代码如下:#include#includeusingnamespacestd;constintN=7;intcoun...

main.cpp

复制代码 代码如下:

#include<iostream>

#include<cstring>

using namespace std;

const int N = 7;

int count = 0;

void QueenPrint(int LayOut[N][N]) //打印结果

{

cout<<"第"<<++count<<"种布局:"<<endl;

for(int i = 0; i < N; i++)

{

for(int j = 0; j < N; j++)

{

if(LayOut[i][j] == 1)

{

cout<<' '<<'Q'<<' ';

}

else

{

cout<<' '<<'*'<<' ';

}

}

cout<<endl;

}

cout<<endl;

}

bool Queen(int LayOut[N][N], const int i, const int j) //判断LayOut[i][j]是否适合放置皇后

{

int k1 = 0;

for(; k1 < N; k1++) //判断该行有没有皇后

{

if(LayOut[i][k1] == 1)

{

return false;

}

}

int k2 = 0;

for(; k2 < N; k2++ ) //判断该列有没有皇后

{

if(LayOut[k2][j] == 1)

{

return false;

}

}

int t1 = i,t2 = j; //判断左上有没有皇后

for(;t1 >= 0 && t2 >= 0;t1--,t2-- )

{

if(LayOut[t1][t2] == 1)

{

return false;

}

}

int n1 = i, n2 = j; //判断右上有没有皇后

for(;n1 >= 0 && n2 < N;n1--,n2++ )

{

if(LayOut[n1][n2] == 1)

{

return false;

}

}

return true;

}

/*

void EightQueen(int LayOut[N][N],int i, int j) // i为行,j为列

{

if( i < N )

{

if( j < N)

{

if(Queen(LayOut,i,j))

{

LayOut[i][j] = 1;

j = 0;

EightQueen(LayOut,i+1, j);

}

else

{

EightQueen(LayOut,i, j+1);

}

}

}

else

{

QueenPrint(LayOut);

}

}*/

void EightQueen(int LayOut[N][N],int i) // i为行

{

if( i == N)

{

QueenPrint(LayOut);

//memset( LayOut, 0, sizeof(LayOut));

}

else

{

int j = 0;

for( ; j < N; j++ )

{

if( Queen( LayOut, i, j))

{

LayOut[i][j] = 1;

EightQueen( LayOut,i+1);

LayOut[i][j] = 0;

}

}

}

}

int main()

{

int LayOut[N][N];

memset( LayOut, 0, sizeof(LayOut));

EightQueen(LayOut,0);

cout<<"共"<<count<<"中结果!"<<endl;

return 0;

}

【八皇后问题实现代码分享】相关文章:

C++产生随机数的实现代码

使用OpenGL实现3D立体显示的程序代码

解析shell排序的实现代码

C++求斐波那契数的实例代码

c++ 巧开平方的实现代码

C++实现:螺旋矩阵的实例代码

C++中给二维指针分配内存(实现代码)

C++ 构造双向链表的实现代码

深入C++实现函数itoa()的分析

简单的汉诺塔问题解法代码

精品推荐
分类导航