



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
符号三角形_实验报告1、 设计分析l 问题描述:在一般情况下,符号三角形的第一行有n个符号。符号三角形问题要求对于给定的n,计算有多少个不同的符号三角形,使其所含的“+”和“-”的个数相同。例如下图:由14个“+”和14个“-”组成的符号三角形。2个同号下面都是“+”,2个异号下面都是“-”。+ + - + - + + + - - - - + - + + + - - + + - - + - - - +l 设计思路: 解向量:用n元组x1:n表示符号三角形的第一行。Xi=1表示第一行第i个符号为“+”, Xi=0表示第一行第i个符号为“-”。 可行性约束函数:当前符号三角形所包含的“+”个数与“-”个数均不超过n*(n+1)/4 。无解的判断:n*(n+1)/2为奇数 。n=3时的符号三角形用完全二叉树表示的解空间。l 复杂度分析: 计算可行性约束需要O(n)时间,在最坏情况下有 O(2n)个结点需要计算可行性约束,故解符号三角形问题的回溯算法所需的计算时间为 O(n2n)。#includeiostream using namespace std; typedef unsigned char uchar; char cc2=+,-; /便于输出 int n, /第一行符号总数 half, /全部符号总数一半 counter; /1计数,即“-”号计数 uchar *p; /符号存储空间 long sum; /符合条件的三角形计数 /t,第一行第t个符号 void Backtrace(int t) int i, j; if( t n ) /符号填充完毕 sum+; /打印符号 cout 第 sum 个:n; for(i=1; i=n; +i) for(j=1; ji; +j) cout ; for(j=1; j=n-i+1; +j) cout cc pij ; cout n; else for(i=0; i2; +i) p1t = i; /第一行第t个符号 counter += i; /“-”号统计 for(j=2; j=2时,可以运算出下面行的某些符号 pjt-j+1 = pj-1t-j+1pj-1t-j+2;/通过异或运算下行符号 counter += pjt-j+1; 2、 程序代码 if( (counter = half) & ( t*(t+1)/2 - counter = half) ) /若符号统计未超过半数,并且另一种符号也未超过半数 Backtrace(t+1); /在第一行增加下一个符号 /回溯,判断另一种符号情况 for(j=2; j=t; +j) counter -= pjt-j+1; counter -= i; int main() cout n; counter = 0; sum = 0; half = n*(n+1)/2; int i=0; if( half%2 = 0 ) /总数须为偶数,若为奇数则无解 half /= 2; p = new uchar *n+1; for(i=0; i=n; +i) pi = new ucharn+1; memset(pi, 0, sizeof(uchar)*(n+1); Backtrace(1); for(i=0; i=n; +i) delete pi; delete p; cout n总共 sum 个 endl; return 0; 三、测试用例4、 实验总结1、 基本上理解了回溯算法。回溯法的基本做法是搜索,或是一种组织得井井有条的、能避免不必要搜索的穷举式搜索法。这种方法适用于解一些组合数相当大的问题。回溯法在问题的解空间树中,按深度优先策略,从根结点出发搜索解空间树。算法搜索至解空间树的任意一点时,先判断该结点是否包含问题的解:如果肯定不包
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 考点攻克苏科版八年级物理下册《力与运动》单元测评试卷(解析版)
- 10 我教学设计-2025-2026学年小学劳动一年级下册人教版生活适应(特殊教育)
- 2025年低空无人机农业病虫害防治市场前景报告
- 期中说课稿-2025-2026学年中职基础课-职业模块工科类-高教版-(英语)-52
- 2025年长江中游城市群低空经济「飞地经济」模式区域协同创新研究报告
- 2025至2030玻璃钢复合材料行业产业运行态势及投资规划深度研究报告
- 二年级语文下册 第三单元 识字 1 神州谣说课稿(pdf) 新人教版
- 2025至2030轻质隔热砖行业项目调研及市场前景预测评估报告
- 重难点解析人教版八年级上册物理《物态变化》专项训练试题(含详解)
- 2025年中小学生趣味百科知识竞赛题库及答案
- 2025年医保政策调整考试题库:影响分析及答案
- 2025年全国保密教育线上培训考试试题库含完整答案(必刷)
- 农村房屋交易合同范本及指南
- 中青班安全生产培训课件
- 六年级语文下册《浪淘沙》教学过程中实录
- 幼儿园教学课件小班社会《孤独的小熊》课件
- 煤矿岗位安全安全操作规程
- 成语故事——井底之蛙课件PPT
- 《鼻咽癌肺癌》ppt课件
- (完整)采光板施工方法
- 函数的单调性第一课时
评论
0/150
提交评论