回溯算法的实验报告_第1页
回溯算法的实验报告_第2页
回溯算法的实验报告_第3页
回溯算法的实验报告_第4页
回溯算法的实验报告_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、-. z.南华大学计算机科学与技术学院实 验 报 告 2016 2017 学年度 第 二 学期 课程名称程序设计语言与编译实验名称回溯算法分析*何星佑*专业树媒班级2地点教师罗江琴实验目的: 通过分析求符号三角形问题的回溯法并编程实现,掌握回溯法的算法框架。实验任务: 分析求符号三角形问题的回溯算法,编程实现,调试运行程序并对运行结果进展分析,分析算法的时空复杂度。实验内容:1、实现回溯法求符号三角形问题描述2、算法描述3、程序设计实验结果与分析:问题描述: 一般情况下,符号三角形的第一行有n个符号,三角形中任意位置都为+或-,且满足以下两个规则: 1三角形中任意行的下一行的符号由以下规则确定

2、:2个同号下面是+,2个异号下面是-; 2三角形中+或-数目一样。对于给定的n,计算有多少个不同的符号三角形。问题分析:对于符号三角形问题,用n元组*1:n表示符号三角形的第一行的n个符号。当*i=1时,表示符号三角形的第一行的第i个符号为+号;当*i=0时,表示符号三角形的第一行的第i个符号为-号;1 i n。由于*i是二值的,所以在用回溯法解符号三角形问题时,可以用一棵完全二叉树来表示其解空间。在符号三角形的第一行的前i个符号*1:i 确定后,就确定了一个由i*i+1/2个符号组成的符号三角形。下一步确定了*i+1的值后,只要在前面已确定的符号三角形的右边加一条边,就可以扩展为*1:i+1

3、所相应的符号三角形。最终由*1:n所确定的符号三角形中包含的+号个数与-号个数同为n*n+1/4。因此在回溯搜索过程中可用当前符号三角形所包含的+号个数与-号个数均不超过n*n+1/4作为可行性约束,用于剪去不满足约束的子树。对于给定的n,当n*n+1/2为奇数时,显然不存在所包含的+号个数与-号个数一样的符号三角形。 程序代码:#include class Trianglefriend int puter(int n);public:void Backtrack(int t);int n, /第一行的符号个数half, /每个三角形总符号数的一半count, /统减号的个数*p; /指向三角

4、形的二维指针long sum; /统计符合条件的的三角形的个数;void Triangle:Backtrack(int t)if (counthalf)|(t*(t-1)/2-counthalf) return; / 如果加号或减号的个数大于符号三角形中总符号数的一半则退出函数if (tn) /符号填充完毕 nsum+; /打印符号for (int i = 1;i=0;k-) /先输出必要的空格 cout ;for (int j = 1;j=n-i+1;j+) /输出符号三角形第i行第i-1+k个位置if (pij = 0) /如果该位为0,输出+cout+ ; else if (pij =

5、1) /如果该位为1,输出- cout- ;coutendl;elsefor (int i = 0;i2;i+)p1t = i; /确定该位置的符号count += i; /假设该位置为减号,则减号数增1,否则,减号数不变for (int j = 2;j=t;j+) /因第t个位置确定,对应三角形的该斜行可以确定pjt-j+1 = pj-1t-j+1pj-1t-j+2; /通过异或运算下行符号count += pjt-j+1; /减号数Backtrack(t+1); /对第一行的第t+1个位置进展回溯算法for (j = 2;j=t;j+) /回溯,减去该斜行的减号数count -= pjt-

6、j+1;count -= i; /减去第一行第t个位置的减号数int puter(int n) /友元函数 调用Triangle类的成员函数Triangle *;*.n = n;*.count = 0;*.sum = 0;*.half = n*(n+1)/2;if (*.half%2 = 1)return 0; /如果是一个三角形符号的总数是奇数则不符合条件,返回0*.half = *.half/2;int *p = new int*n+1; /分配新行for(int i = 0;i=n;i+) pi = new int n+1; /分配新列for(i = 0;i=n;i+)for(int j = 0;j=n;j+)pij = 0; /给p所指向的二维数组赋值为0*.p = p;*.Backtrack(1);return *.sum;void main()int n; /第一行的符号数c

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论