马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 致年轻的我们 于 2016-11-8 18:43 编辑
问题引入:国际象棋的八皇后问题。
在国际象棋中,“皇后”可以吃掉与自己同一条横行,纵行或斜线上的棋子,现在在8x8的国际象棋棋盘上放置八个“皇后”,使得任何一个“皇后”都无法直接吃掉其他的“皇后”,因此,任意两个“皇后”都不能处于同一条横行,纵行或斜线上。使用编程计算共有多少种棋子摆放的方式?
实现代码如下,主要运用了函数递归实现数字全排列的方法,代码作者:望尘11,本人感觉不错,摘抄分享给大家。/************
***望尘11***
************/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
void fun(int array[],int len,int pos1);
//void printArray(int array[],int len);
void printRect(int array[8]);
int number=0;
int main()
{
printf("start\n");
int array[]={0,1,2,3,4,5,6,7};
fun(array,sizeof(array)/sizeof(int),0);
printf("共有以上%d种方案\n",number);
printf("end\n");
return 0;
}
int isRight(int array[8])
{
int i,j;
for(i=0;i<8;i++)
{
for(j=0;j<8;j++)
{
if(i!=j)
{
if(abs(i-j)==abs(array[i]-array[j]))
return 0;
}
}
}
return 1;
}
void fun(int array[],int len,int pos1)
{
int i;
if(pos1>=len-1)
{
if(isRight(array))
{
number++;
//printArray(array,len);
printRect(array);
}
}
else
{
for(i=pos1;i<len;i++)
{
int temp;
temp=array[pos1];
array[pos1]=array[i];
array[i]=temp;
fun(array,len,pos1+1);
temp=array[pos1];
array[pos1]=array[i];
array[i]=temp;
}
}
}
//void printArray(int array[],int len)
//{
// int i;
// for(i=0;i<len;i++)
// {
// printf("%d\t",array[i]);
// }
// printf("\n");
//}
void printLine(int n)
{
int i=0;
for(i=0;i<8;i++)
{
printf("%s",n==i?"○":"口");
}
printf("\n");
}
void printRect(int array[8])
{
int i=0;
for(i=0;i<8;i++)
{
printLine(array[i]);
}
printf("\n");
}
如果你有方法更好,效率更高的代码,欢迎分享回复。
分享一个编程交流群,不犯规吧:快写代码官方群:136898517
犯规通知我,我会删除,谢谢。
这是我的第一个帖子,多多支持。 |