已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
八皇后问题求解(1) 实验目的1. 熟悉人工智能系统中的问题求解过程;2. 熟悉对八皇后问题的建模,求解及编程语言的应用。(二)实验内容八皇后问题是19世纪著名的数学家高斯于1850年提出的。他的问题是:在8*8的棋盘上放置8个皇后,使其不能相互攻击,即任意两个皇后都不能处于同一行,同一列,同一斜线上。请设计算法打印出所有可能的摆放位置。(3) 实验代码#include stdafx.h#include#includeusing namespace std;#define N 10class Queenpublic:Queen() num = -1; void Print(int n);/输出皇后的排列,打出的数字为每个皇后的坐标int Check(int i, int k);/判断位置是否符合要求void Queens(int k, int n);/递归调用int count();/计数private:int qN;int num;void main()Queen Q;int n;cout 0): n;if (n0)cout Queen可能的位置坐标: endl;Q.Queens(1, n);cout 共有 Q.count() 种方法放置Queen endl;elsecout ERROR输入数字错误 n)/如果达到里要求的数量输出皇后排列Print(n);count();else /否则在适当的位置添加一个新皇后for (i = 1; i = n; i+)if (Check(i, k) /判断该行中该位置放置皇后是否符合要求qk = i; /记录改行中该点的位置Queens(k + 1, n); /放置下一行的皇后void Queen:Print(int n)int i;for (i = 1; i = n; i+)cout ( i , qi );cout endl;int Queen:Check(int i, int k)int j;j = 1;while (jk)if (qj = i) | abs(qj - i) = abs(j - k) /判断列,判断斜线return 0; /不符合返回0j+;return 1;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 心血管疾病精准风险分层与护理干预
- 心血管疾病一级预防的精准营养干预策略
- 心脏移植供体分配的医疗资源均衡配置
- 心脏瓣膜器械个性化治疗策略
- 心脏康复中的药物安全边界
- 心肌病心肌代谢评估的多组学整合分析策略
- 心理学技术在慢性病行为干预中的应用
- 微生物组与肠脑轴疾病的干预策略
- 微创缝合技术对硬脑膜修补患者生活质量的影响
- 微创手术治疗脊髓血管畸形技术优化
- 智能工厂项目培训
- 《组织传播学》教材
- GB 46520-2025建筑用绝热材料及制品燃烧性能安全技术规范
- 竖井通风管道施工技术方案
- 2025年低空经济行业碳排放核算方法与案例分析报告
- 乡土中国血缘和地缘
- 一流专业验收汇报
- 水利工程维护保养手册
- 城市更新项目申报2025年申报指南与方案
- 绿化工程分包合同协议书3篇
- 企业安全管理事故后复工影响评估与风险防控
评论
0/150
提交评论