- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * C++中的变量有数据类型和存储类型两种属性。进行完整的变量声明,除了声明其数据类型之外,有时还需声明其存储类型。程序运行时,系统出了为程序的可执行代码分配内存,还为不同的存储属性的变量分配不同类型的存储空间。存储类型说明了变量在内存中的存储方式,而存储方式决定了变量的生存期。 * * * * * * 由于其速度非常快,用来给CPU传递数据,内存和外部存储器里的数据都是先读到寄存器里再送给CPU的。 * * 程序执行到 A 行时,系统为寄存器变量 m 、 n 分配寄存器完成数据的加法工作,执行到 B 行时系统回收为 m 、 n 分配的寄存器,因此, m 、 n 的生存期是从 A 行到 B 行。在 for 语句两次循环中,系统两次为 m 、 n 分配寄存器并赋初值 0 ,又两次回收寄存器。因此,两次循环的输出结果是相同的。 * 因此当对一个变量频繁读写时,必须要反复访问内存储器,从而花费大量的存取时间。 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Hanoi(汉诺塔问题) 一个古典的数学问题: 古代有一个梵塔,塔内有3个座A、B、C,开始时A座上有64个盘子,盘子大小不等,大的在下,小的在上。 有一个老和尚想把这64个盘子从A 座移动到C 座,每次只允许移动一个盘,且在移动过程中,在每个座上都始终保持大盘在下,小盘在上。在移动过程中可以利用B 座,写出移动步骤。 这是一个只有用递归方法才能解决的问题。 A B C 分析3个盘子的情况: 1. 将A座上2个盘子移到B座 (借助C); 2. 将A座上1个盘子移到C座; 3. 将B座上2个盘子移到C座 (借助A)。 其中第2 步可以直接实现。 第1、3步还需要递归分解。 A B C A B C A B C 递归分解: 第1 步——将A座上2个盘子移到B座(借助C),分解为: 1.1 将A上一个盘子从A移到C; 1.2 将A上一个盘子从A移到B; 1.3 将C上一个盘子从C移到B。 A B C 1.1 A B C 1.2 A B C 1.3 A B C 3. 第3步——将B座上2个盘子移到C座 (借助A),分解为: 3.1 将B上一个盘子从B移到A; 3.2 将B上一个盘子从B移到C; 3.3 将A上一个盘子从A移到C。 将以上综合起来,可得到移动3个盘子的步骤为: A→C,A →B,C →B, A →C, B →A,B →C,A →C。 共经历7(=23-1)步。 可以推知,移动 n 个盘子需要经历2 n -1。 1. 将A 座上n-1个盘子借助C 座移到B 座上 ; 2. 将A 座上剩下的1个盘子移到C 座上; 3. 将B 座上n-1个盘子借助A 座移到C 座上 。 将第1步和第3步表示为: 将“one” 座上n-1个盘子借助“two”座移到“three”座。只是在第1 步和第3 步中,one、two、three和A、B、C的对应关系不同。 对第1步,对用关系是:one——A,two——C,three——B。 对第3步,对用关系是:one——B,two——A,three——C。 因此,可以将上面的3个步骤分成两类操作: ⑴ 将n-1个盘子从一个座移到另一个 座上(n1) ; ⑵ 将1个盘子从一个座移到另一个 座上; 分别用两个函数来实现这两类操作。hanoi (n, one, two, three) 表示“ 将n 个盘子从one 座借助two 座移到three 座,函数move(x, y) 表示将一个盘子从x 座移到y 座。one、two、three、x 和y 对应不同情况的 A、B、C。 将n 个盘子从A 座移到C 座,可以分解为3个步骤: 汉诺塔程序: void move(char x, char y) { cout xy;} void hanoi( int n, char one, char two, char three) { if (n= =1) move(one, three); else { hanoi( n-1, one, three, two); move(one, three); hanoi( n-1, t
文档评论(0)