全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
算法分析与设计实验报告实验名称: 随机与回溯结合解决N后问题 课程名称: 算法分析与设计 姓名: 李少卿 专业班级: 计算机科学与技术08-1班 学号: 200807010119 日期: 2011.06.01 地点: 西一楼207 成绩: 地点: 苏晓珂、李灿林 1.实验目的结合随机算法和回溯求解N皇后问题,使得在NxN格的国际象棋上摆放N个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上。2.实验内容(1) 算法分析N皇后问题一般是采用回溯法求解,但当N值较大时,回溯算法效率较低,所以此次作业中将随机算法和回溯法结合起来求解N皇后问题,以提高算法的效率。引入随机算法,能保证每次找出的解是正确的,但可能在一次求解过程中找不出可行解,这一点在程序运行过程中能得到体现。所以解决N皇后问题所采取的方法是先用随机函数产生一部分的解(这一部分可以占全部的三分之一),再用回溯法将其余的结果计算出来。(2) 源代码#include #include #include using namespace std;int count,rand_count;/判断第k个皇后的位置是否满足要求bool place(int x,int k) int i; for (i = 1;ik;+i) if ( (xi=xk)|( abs(xi-xk)=abs(i-k) ) ) return false; return true;/回溯法+随机法求解n皇后问题void Rand_Back_n_queens(int n,int x) int k,mid; mid = n/3; time_t t; srand(unsigned) time(&t);printf(n随机产生的值:n); for (k = 1;kmid) +xk; while ( (xk=n)&(!place(x,k) ) +xk; if (xk=n) if (k=n) break; else +k; xk = 0; else xk = 0; -k; printf(n回溯法产生的值:n); for (int i = mid+1; i=n; +i) printf(%dt,xi);int main() int n; printf(回溯法+随机法求解n皇后问题,请输入n值(输入0则退出): ); while (scanf(%d,&n),0!=n) int *x = new intn+1; Rand_Back_n_queens(n,x); delete x; x = NULL; printf(nn请输入n值(输入0则退出): ); return 0;(3) 实验结果输入代码后编译并调试程序。当N等于8、9、10的时候分别可以得到以下的结果:3.总结与回顾在这次试验的代码设计中使用了随机函数来求得三分之一的解。首先要解决的问题就是随机函数的问题。随机函数是一个获得随机数很方便的工具,但是由于该函数的局限性,它每次重新开始运行时所产生的随机数都是相同的,就是获得了相同的数据,从而失去了它的随机性。所以随机函数就便成了伪随机函数。为了解决这个问题,我使用了时间函数来作为随机种子。从而使得每次获得的数据都因为时间的不同而不同。其次就是随机函数所产生的数据不一定是正确的解,所以每次产生随机数之后还要判断一下,不符合题目要求的要删掉,并重新执行随机函数直到产生正确的解。然后就是用之前所学到的回溯法来求得余下的解了。求解过程和单独用回溯法一样,不过因为上面产生随机解的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中国摩托车发动机油项目投资可行性研究报告
- 中国磁性内胆学生用尺项目投资可行性研究报告
- 中医针刺技能大赛题库及答案
- 中国窄幅柔版水性油墨项目投资可行性研究报告
- 中国样布项目投资可行性研究报告
- 中国塑胶模具-杯项目投资可行性研究报告
- 智能感应卡行业深度研究报告
- 维护网络安全运行承诺书说明函件函告8篇
- 中国辣椒菜项目投资可行性研究报告
- 中国矿料冶炼项目投资可行性研究报告
- 开户风险测评建议答案
- 生态监测课件
- 旅游景区管理制度汇编大全
- 【新版】大型苯酐生产企业车间工艺设计实施项目可行性方案
- 高铁客专联调联试工作总结-工作总结
- 高质量SCI论文入门必备从选题到发表全套课件
- 树木移栽移植施工方案
- 初中物理竞赛专题五-力的合成与分解(小专题)
- 人教版一年级数学上册期中试卷 (5)
- 空白现金流量表会小企03表及(续)
- 华为接待直通车--市场客户接待业务流程
评论
0/150
提交评论