



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
关于符号三角形数与n的关系的研究与实现云南师范大学 计算机应用技术 张书涵1 问题描述在一般情况下,符号三角形的第一行有n个符号。符号三角形问题要求对于给定的n,计算有多少个不同的符号三角形,使其所含的“+”和“-”的个数相同。例如图1:由14个“+”和14个“-”组成的符号三角形。2个同号下面都是“+”,2个异号下面都是“-”。+ + - + - + + - - - - +- + + + - + + - + - -+ 图1 符号三角形本文就是计算有多少个不同的符号三角形,使其所含的“+”和“-”的个数相同,并且探讨两种符号数相同的不同符号三角形的个数与n的关系。2 问题分析用n元组x1:n表示符号三角形的第一行。Xi=1表示第一行第i个符号为“+”, Xi=0表示第一行第i个符号为“-”。可行性约束函数为,当前符号三角形所包含的“+”个数与“-”个数均不超过n*(n+1)/4 。容易看出,第1行n个符号的数值不同,将直接导致符号三角形的数值F(n)不同。显然,符号三角形的个数F(n)是随着n的变化而变化。那么,得知F(n)与n必然存在一种关系。其次,一个符号三角形有n(n+1)/2个符号,显然这个公式的分子n,n+1中必有一个为偶数。记G(n)为一个符号三角形所包含的符号数,假定n为偶数。则上述的公式可改写成:。而且n/2必须再次为偶数,不然就不满足条件:符号三角形的符号数G(n)所含的“+”和“”的个数相同。所以,n必然是4的倍数,即n=4k,其中k=1,2,3,。根据上面的论述,易知当公式的分子n,n+1中有且只有一个为4的倍数,此探讨才有意义,并且研究的条件再次收缩。3 问题解决 用穷举法列出n和符号数以及符号三角形数F(n)的映射表,如表1所示。n符号总数符号三角形个数F(n)110230364410651506210728128364094501055011661711278410表1 n和符号数以及符号三角形数F(n)的映射表根据穷举的结果我们也可以看出,当n=4i或n=4i-1(i=1,2,3,4)时存在符号三角形,当n=4i-2或4i-3时不存在符号三角数。4 运行结果 5 总结通过上述的分析,基本上理解了回溯算法。当n=4i或n=4i-1(i=1,2,3,4)时存在符号三角形,当n=4i-2或4i-3时不存在符号三角数。但是运用现有的技术很难得到F(n)关于n的精确表达式。所以,这个问题还有待进一步研究。附录:程序代码:#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; 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, sizeo
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 如何分析一篇文章的结构
- 人寿保险购买制度
- 宴会厅用餐流程规范制定
- 农村精准扶贫政策实施方案
- 印刷工艺课程标准与教学设计汇编
- 酒店餐饮成本核算与控制方法
- 屋面防水施工质量保证方案
- 小学五年级行为养成总结报告
- 施工现场质量控制流程标准
- 加强内部审计质量控制的有效措施
- 2023年广东生物高考第18题光合作用说题课件
- 除锈剂MSDS参考资料
- 6社会体育导论
- 部编版七年级历史与社会下册《第三课中华文明探源》评课稿
- 中考英语作文预测(范文20篇)
- 选煤厂原煤分级筛技术操作规程
- 方物电子教室q2用户手册
- 消防管道支架工程量计算表
- GB/T 700-2006碳素结构钢
- 腹腔镜下肾癌根治术
- 如何学好初中数学-课件
评论
0/150
提交评论