四、八、N皇后问题(数据结构C语言)
更新时间:2023-08-25 16:45:01 阅读量: 教育文库 文档下载
- 四皇后问题图解推荐度:
- 相关推荐
欢迎交流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;
}
正在阅读:
四、八、N皇后问题(数据结构C语言)08-25
环境保护行政执法的现状及对策12-31
配套K122018年秋九年级数学下册 第1章 解直角三角形 1.303-11
社区矫正心得体会 个人感悟三篇09-12
Dosbox安装windows9810-22
教育论文04-24
高中物理课堂导学与针对训练(第二、三册)10-15
演讲致辞-妙语连珠让你魅力四射 精品12-28
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 数据结构
- 皇后
- 语言
- 问题
- 台湾问题中的美国因素
- 铵盐 硝酸高三一轮复习
- 论文:宜家家居的品牌策略研究
- 专业技术工作报告
- 机组启动试运行方案烟峰
- 八年级物理上册 4.2《探究汽化和液化的特点》拔高练习2 (新版)粤教沪版
- 内蒙古通辽实验中学2017-2018学年高二下学期期中考试物理试题含答案
- 催缴物业费的公告函(1)
- 计量经济学关于税收收入影响因素分析
- 如何有效引导学生与文本对话
- 电梯钢结构报价表
- 2013年船舶工业经济运行分析
- 商标炒卖初行其道
- keil4 for51与keil for arm共存
- 铂电阻温度计测量结果和不确定度评定报告2(2011-11-16 07.51.02)
- linux入门视频教程
- 禅、禅学与学禅
- 九年级物理第十三章《力和机械》单元检测题
- 福建省福鼎市十校教研联合体2014-2015学年七年级上学期期中联考英语试题
- 分析化学课后习题及答案