四、八、N皇后问题(数据结构C语言)
欢迎交流346282925
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<conio.h>
#define Max 20/*定义棋盘的最大值*/
int a[Max];
int show(int S)/*定义输出函数*/
{
int i;
int p,q ;
int b[Max][Max]={0};/*定义并初始化b[][]输出数组*/
static t=1;
for(i=1;i<=S;i++)/*按横列i顺序输出a[i]数组坐标*/
{
b[i][a[i]]=1;
printf("(%d,%d)\t",i,a[i]);
}
printf("\n");
for(p=1;p<=S;p++)/*按棋盘的横列p顺序标明皇后的位置*/
{
for(q=1;q<=S;q++)
{
if(b[p][q]==1) /*在第p行第q列放置一个皇后棋子*/
printf("●");
else
printf("○");
}printf("\n");
}
return 0;
}
int check(int n)/*定义check函数*/
{
int i;
for(i=1;i<n;i++)
{
if((a[i]==a[n])||(a[i]-a[n]==n-i)||(a[i]-a[n]==i-n)) /*检查是否有多个皇后在同一条直线上*/
{
return 0;
}
}
return 1;
}
void check_m(int so)/*定义函数*/
{
int k=1,count=0;
printf("The possible configuration of N queens are:\n");
a[k]=1;
while(k>0)
{
if(k<=so&&a[k]<=so)/*从第k行第一列的位置开始,为后续棋子选择合适位子*/
{
if(check(k)==0)/*若满足函数check()==0,a[k]+1继续循环*/ {
a[k]++;
}
else
{
k++;/*确定第K行的棋子位置,继续寻找第k+1行棋子位置*/ a[k]=1;
}
}
else
{
if(k>so)/*若满足输出数组的要求则输出该数组*/
{
count++;
printf("[%d]: ",count);
show(so);/*调用输出函数show()*/
}
k--;/*棋子位置不符合要求,则退回前一步*/
a[k]++;/*继续试探下一列位置*/
}
}
printf("The count is: %d \n",count);
}
int main()
{
int N;
int d;
system("color 2a");
do
{
printf("********************N皇后问题系统*********************\n\n"); printf(" 1. 四皇后问题 \n"); printf(" 2. 八皇后问题 \n"); printf(" 3. N 皇后问题(N<20) \n"); printf(" 4. 退出 \n"); printf("******************************************************\n"); printf("\n 从数字1-4之间的数选择需要的操作\n\n"); /*提示输入选项*/ printf(" 请输入你要选择的功能选项:__\n");
scanf("%d",&d);
switch(d)
{
case 1:
check_m(4);/*4皇后问题*/
break;
case 2:
check_m(8);/*8皇后问题*/
break;
case 3:
printf("请输入N的值:_");
fflush(stdin);/*清除缓冲*/
scanf("%d",&N);
printf("\n");
if(N>0&&N<20)
{
check_m(N);/*N皇后问题*/
break;
}
else
{
printf("输入错误,请从新输入:");
printf("\n\n");
break;
}
case 4:
exit(0); /*程序结束*/
}
}while(1);
return 0;
}
相关推荐:
- [高等教育]一年级家长课程教案
- [高等教育]封丘县人民医院深入推进纠正医药购销领
- [高等教育]2017年6月大学英语四级真题试卷及答案(
- [高等教育]2017年北京第二外国语学院文学院824中
- [高等教育]7 高中历史第7单元1861年俄国农奴制改
- [高等教育]【K12学习】4、实际测量-苏教版六年级
- [高等教育]药具培训试卷题库及部分参考答案
- [高等教育]本土电子元器件目录分销商如何赢得生意
- [高等教育]七年级岭南版美术教案
- [高等教育]书作文之书法活动通讯稿
- [高等教育]Endnote X 软件使用入门和用法总结(LS)
- [高等教育]嵌入式系统的现状及发展状况
- [高等教育]2012抗菌药物专项整治活动方案解读
- [高等教育]人教版新课本一年级数学下册期末试卷
- [高等教育]爱课程民法学观后感
- [高等教育]930机组使用说明书1
- [高等教育]煤气设备设施点检标准
- [高等教育]常见室内观叶植物图解
- [高等教育]312党员群众路线心得体会
- [高等教育]小学信息(苗版)第一册全册教案
- 在市---局2010党建大会上的讲话
- 《科哲》提纲及补充阅读材料(2010.7)
- 苏州高博软件技术职业学院论文开题报告
- 兼职导游管理的困境及对策探讨
- 基于通用设计理念的现代厨房产品语义研
- 康乐一中2010年至2011年度鼓号队、花束
- 第10章_数据收集整理与描述_期末复习课
- 2008年黑龙江林甸商贸购物中心营销策划
- 水硬度的测定实验报告
- 五分钟教你拍摄夜景光绘照
- 2014年临床妇产科三基三严试题及答案
- 0第二课 纾解压力第一站了解压力
- 解析建筑工程电气设备安装施工技术要点
- 地方性应用型本科高校“双师型”师资队
- 高考语文专题复习课件:小说阅读指导
- 装饰工程投标书2
- 大学生就业难问题探讨及对策
- English and Its History
- 青岛市城市房屋修缮工程质量监督管理办
- 初中英语形容词和副词的用法和练习题




