- 4
- 0
- 约1.84万字
- 约 105页
- 2016-12-25 发布于未知
- 举报
相传古代印度布拉玛神庙中有一个僧人,他每天不分白天黑夜,不停地移动那些圆盘,据说,当所有64个圆盘全部从一根杆上移到另一根杆上的那一天就是世界的末日。故汉诺塔问题又被称为“世界末日问题”。 玩汉诺塔游戏/flash/293_1.htm 看视频:/v_show/id_XMjU0MzU0NDQ0.html 可执行的程序 int i=0; /* 移动圆盘数量计数器 */ main( ) { unsigned n; scanf (%d, n); movedisc ( n,‘a’,‘b’,‘c’); /* 将A上的N个圆盘借助C将移动到B上 */ printf( \t Total: %d\n, i ); } movedisc ( n, fromneedle, toneedle, usingneedle ) unsigned n; char fromneedle, toneedle, usingneedle; { if ( n == 1 ) printf(%2d-(%2d): %c == %c\n, ++i, n, fromneedle, toneedle); else { movedisc ( n-1, fromneedle, usingneedle, toneedle ); printf(%2d-(%2d): %c == %c\n, ++i, n, fromneedle, toneedle); movedisc ( n-1, usingneedle, toneedle, fromneedle ); } } 看程序演示 * 以n!解释递归调用: 1. 进入TC环境,先用非递归(循环的方法)求解10!。 解决几个易错的问题: 程序中储存结果的变量先说明为int型,(long型) 函数说明为int型,(long型) 改正以上错误后,函数内结果对,主函数显示错误。 主调函数未对被调函数说明。 单步执行时观察变量 s(结果)、i+1。 2. 改为递归调用算法,在写程序过程中解释: 什么是自己调自己? 强调不是简单的复制,每次调用参数是不同的。 递归调用结束的条件。 单步执行时观察变量每次的参数n的值。 注意怎么返回的。 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 以n!解释递归调用: 1. 进入TC环境,先用非递归(循环的方法)求解10!。 解决几个易错的问题: 程序中储存结果的变量先说明为int型,(long型) 函数说明为int型,(long型) 改正以上错误后,函数内结果对,主函数显示错误。 主调函数未对被调函数说明。 单步执行时观察变量 s(结果)、i+1。 2. 改为递归调用算法,在写程序过程中解释: 什么是自己调自己? 强调不是简单的复制,每次调用参数是不同的。 递归调用结束的条件。 单步执行时观察变量每次的参数n的值。 注意怎么返回的。 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 10的阶乘的递归过程: 10!= 10 * 9! 9!= 9 * 8! 8!= 8 * 7! 7!= 7 * 6! 6!= 6 * 5! 5!= 5 * 4! 4!= 4 * 3! 3!= 3 * 2! 2!= 2 * 1! 1!= 1 * 0! 0!= 1 1 = 1 1 = 2 2 = 6 6 = 24 24 = 120 120 = 720 720 = 5040 5040 = 40320 40320 = 362880 362880 = 3628800 递推算法求解过程: 1!= 1 2!= 1*2 = 2 3!= 2*3 = 6 4!= 6*4 = 24 5!= 24*5 = 120 6!= 120*6 = 720 7!= 720*7 = 5040 8!= 5040*8 = 40320 9!= 40320*9 = 362880 10!= 362880*10 = 3628800 第五模块 计算机程序设计基础 第四节 基本算法 6.2 算法与算法设计 例:汉诺塔问题 汉诺塔(Hanoi)问题是一个著名的问题,其来源据说是在约19世纪末欧洲的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下、由小到大顺序串着由64个圆盘构成的塔,游戏的目的是
您可能关注的文档
- 解放思想跨越发展大讨论实施方案.doc
- 解放战争导学案.doc
- 解放石家庄60周年竞赛材料.doc
- 解构主义批评DECONSTRUCTION专题.doc
- 解析施工人员做好安全施工需求思考的方法中英文.doc
- 解读-碳排放权交易管理暂行办法.doc
- 解读2012年安徽省初中(物理)毕业学业考试纲要(王庆生).ppt
- 解读《文化生活》全书的内容.ppt
- 解读与建构:高职院校校企合作公共政策发展研究.doc
- 解读功能性消化不良和肠易激综合征-柯美云.ppt
- 广东省广州省实验中学教育集团2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 广东省广州大学附属中学2025-2026学年八年级上学期奥班期中物理试题(解析版).docx
- 广东省广州市第八十六中学2025-2026学年八年级上学期期中物理试题(含答案).docx
- 广东省广州市第八十九中学2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 广东省广州市第二中学2025-2026学年八年级上学期期中考试物理试题(含答案).docx
- 广东省广州市第八十六中学2025-2026学年八年级上学期期中物理试题(解析版).docx
- 广东省广州市第八十九中学2025-2026学年八年级上学期期中考试物理试题(含答案).docx
- 广东省广州市第二中学2025-2026学年八年级上学期期中考试物理试题(解析版).docx
- 2026《中国人寿上海分公司营销员培训体系优化研究》18000字.docx
- 《生物探究性实验教学》中小学教师资格模拟试题.docx
原创力文档

文档评论(0)