- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C八皇后38
在一个8×8国际象棋盘上,有8个皇后,每个皇后占一格;要求皇后间不会出现相互“攻击”的现象,即不能有两个皇后处在同一行、同一列或同一对角线上。问共有多少种不同的方法。
*问题分析与算法设计这是一个古老的具有代表性的问题,用计算机求解时的算法也很多,这里仅介绍一种。采用一维数组来进行处理。数组的下标i表示棋盘上的第i列,a[i]的值表示皇后在第i列所放的位置。如:a[1]=5,表示在棋盘的第一例的第五行放一个皇后。程序中首先假定a[1]=1,表示第一个皇后放在棋盘的第一列的第一行的位置上,然后试探第二列中皇后可能的位置,找到合适的位置后,再处理后续的各列,这样通过各列的反复试探,可以最终找出皇后的全部摆放方法。程序采用回溯法,算法的细节参看程序。
*程序说明与注释#includestdio.h#define NUM 8 /*定义数组的大小*/int a[NUM+1];int main(){int i,k,flag,not_finish=1,count=0;i=1; /*正在处理的元素下标,表示前i-1个元素已符合要求,正在处理第i个元素*/a[1]=1; /*为数组的第一个元素赋初值*/printf(The possible configuration of 8 queens are:\n);while(not_finish) /*not_finish=1:处理尚未结束*/{while(not_finishi=NUM) /*处理尚未结束且还没处理到第NUM个元素*/{for(flag=1,k=1;flagki;k++) /*判断是否有多个皇后在同一行*/if(a[k]==a[i])flag=0;for(k=1;flagki;k++) /*判断是否有多个皇后在同一对角线*/if((a[i]==a[k]-(k-i))||(a[i]==a[k]+(k-i))) flag=0;if(!flag) /*若存在矛盾不满足要求,需要重新设置第i个元素*/{if(a[i]==a[i-1]) /*若a[i]的值已经经过一圈追上a[i-1]的值*/{i--; /*退回一步,重新试探处理前一个元素*/if(i1a[i]==NUM)a[i]=1; /*当a[i]为NUM时将a[i]的值置1*/else if(i==1a[i]==NUM)not_finish=0; /*当第一位的值达到NUM时结束*/else a[i]++; /*将a[i]的值取下一个值*/}else if(a[i]==NUM) a[i]=1;else a[i]++; /*将a[i]的值取下一个值*/}else if(++i=NUM)if(a[i-1]==NUM) a[i]=1; /*若前一个元素的值为NUM则a[i]=1*/else a[i]=a[i-1]+1; /*否则元素的值为前一个元素的下一个值*/}if(not_finish){++count;printf((count-1)%3? [%2d]: : \n[%2d]: ,count);for(k=1;k=NUM;k++) /*输出结果*/printf( %d,a[k]);if(a[NUM-1]NUM) a[NUM-1]++; /*修改倒数第二位的值*/else a[NUM-1]=1;i=NUM-1; /*开始寻找下一个足条件的解*/}}}
*思考题一个8×8的国际象棋盘,共有64个格子。最多将五个皇后放入棋盘中,就可以控制整个的盘面,不论对方的棋子放哪一格中都会被吃掉。请编程找出这样的五个“皇后”可能的布局。
今天上午考计算方法,有个题要求编程求解八皇后问题,我把大一时写的程序写上去了,HOHO~!~! 在一个8×8的棋盘上放置8个皇后,使得他们彼此不受攻击。按照国际象棋的规则,一个皇后可以攻击处在同一行或者同一列或者同一斜线上的其它任何棋子。 #include?stdio.h #include?stdlib.h #include?math.h int?Judge(int?*p,?int?j) //判断当前棋子位置是否符合规则,是则返回1,否则返回0; { int?i; for(i=0;ij;i++) { ?if(p[j]==p[i]) return?0; ?if(abs(p[j]-p[i])==j-i) return?0; } return?1; } int?main() { int?a[8]; //a[i]表示第i行的后所在位置(a[3]=0表示第3行的后在第0列) int?i=0,j=0,k=0;
您可能关注的文档
- 8年级上第6课同学之缘133.ppt
- 8水泥成品、半成品和原料的化学分析40.ppt
- 8我不能失信30.ppt
- 8卡罗尔和她的小猫 课件49.ppt
- 8班长的烦恼9.ppt
- 8第二编基础理论第八章证据(二简,补充了两个证据规定)43.ppt
- 8路旁的橡树PPT21.ppt
- 8第7章2 回转体19.ppt
- 8道简单的煲仔饭17.doc
- 8黄元御中气升降理18.ppt
- 数据仓库:Redshift:Redshift与BI工具集成.docx
- 数据仓库:Redshift:数据仓库原理与设计.docx
- 数据仓库:Snowflake:数据仓库成本控制与Snowflake定价策略.docx
- 大数据基础:大数据概述:大数据处理框架MapReduce.docx
- 实时计算:GoogleDataflow服务架构解析.docx
- 分布式存储系统:HDFS与MapReduce集成教程.docx
- 实时计算:Azure Stream Analytics:数据流窗口与聚合操作.docx
- 实时计算:Kafka Streams:Kafka Streams架构与原理.docx
- 实时计算:Kafka Streams:Kafka Streams连接器开发与使用.docx
- 数据仓库:BigQuery:BigQuery数据分区与索引优化.docx
最近下载
- 叉车司机 国家职业能标准.doc VIP
- 初中物理 2023-2024学年云南省曲靖市八年级(下)期末物理试卷.pdf VIP
- Siemens 西门子家电 洗衣干衣机 WN54A3X00W 产品功能表.pdf
- 工会基础知识考试题库【附答案】.docx VIP
- 履带吊安拆专项施工方案(专家会) (1).docx VIP
- 会展搭建供应商入围项目 投标方案(技术标115页).docx VIP
- 11BS3给水工程华北标图集.docx VIP
- DB37T 4199-2020 中小学校食堂建设与设备配置规范.docx VIP
- 长输管道工程项目管理的建议及对策.docx VIP
- 4.严重违法行为平台服务停止制度.pdf VIP
文档评论(0)