下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 HYPERLINK /feixiaoxing/article/details/6871148一步一步写算法(之爬楼梯) 前两天上网的时候看到一个特别有意思的题目,在这里和朋友们分享一下: 有一个人准备开始爬楼梯,假设楼梯有n个,这个人只允许一次爬一个楼梯或者一次爬两个楼梯,请问有多少种爬法? 在揭晓答案之前,朋友们可以自己先考虑一下: 这个人爬n层楼梯,那么它也不是一下子就可以爬这么高的,他只有两个选择,要么从n-2层爬过来,要么从n-1层爬过来。除此之外,他没有别的选择。此时相信朋友其实已经早看出来了,这就是一道基本的递归题目。 (1)首先我们建立一个函数,判断函数的合法性cpp HYPE
2、RLINK /feixiaoxing/article/details/6871148#view plainHYPERLINK /feixiaoxing/article/details/6871148#copyvoid jump_ladder(int layer, int* stack, int* top) if(layer = 0) return; return; (2)判断当前的层数是为1或者是否为2cpp HYPERLINK /feixiaoxing/article/details/6871148#view plainHYPERLINK /feixiaoxing/article/detai
3、ls/6871148#copyvoid jump_ladder(int layer, int* stack, int* top) if(layer = 0; index -) printf(%d, stackindex); printf(n); while(0) void printf_layer_one(int layer, int* stack, int* top) int index ; GENERAL_PRINT_MESSAGE(1); void printf_layer_two(int layer, int* stack, int* top) int index; GENERAL_P
4、RINT_MESSAGE(11); GENERAL_PRINT_MESSAGE(2); 注: a)代码中我们使用了宏,注意这是一个dowhile(0)的结构,同时我们对x进行了字符串强转 b)当剩下台阶为2的时候,此时有两种情形,要么一次跳完;要么分两次 (4)当阶梯不为1或者2的时候,此时需要递归处理cpp HYPERLINK /feixiaoxing/article/details/6871148#view plainHYPERLINK /feixiaoxing/article/details/6871148#copyvoid _jump_ladder(int layer, int* st
5、ack, int* top, int decrease) stack(*top)+ = decrease; jump_ladder(layer, stack, top); stack-(*top) = 0; void jump_ladder(int layer, int* stack, int* top) if(layer = 0) return; if(layer = 1) printf_layer_one(layer, stack, top); return; if(layer = 2) printf_layer_two(layer, stack, top); return; _jump_ladder(layer- 1, stack, top, 1); _jump_ladder(layer- 2, stack, top, 2); 祝:这里在函数的结尾添加了一个函数,主要是递归的时候需要向堆栈中保存一些数据,为了代码简练,我们重新定义了一个函数。总结: 1)这道题目和斐波那契数列十分类似,是一道地地道道的递归题目 2)递归的函数也需要好好测试,使用
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 高中化学 第四章 非金属及其化合物 4.4 氨硝酸硫酸硫酸教案2 新人教版必修1
- 2024-2025学年新教材高中物理 第六章 4 生活中的圆周运动教案 新人教版必修2
- 八年级语文上册 第四单元 16 大自然的语言教案 新人教版
- 2024年秋八年级地理上册 第一章 中国的疆域与人口 1.3《中国的人口》教案 (新版)湘教版
- 七年级地理上册 第一章 第一节 我们身边的地理知识教学设计 湘教版
- 广东省肇庆市高中地理 第二章 城市与城市化 2.3 城市化(2)教案 新人教版必修2
- 智能企业社会责任审计系统开发合同
- 七年级道德与法治下册 第二单元 做情绪情感的主人 第五课 品出情感的韵味 5.1 我们的情感世界教案 新人教版
- 无人机行业智能飞行与监控方案
- 八年级政治上册 第二单元 善待他人 2.1 诚实守信教案(扫描版) 粤教版
- 财务主管岗位招聘笔试题及解答(某大型集团公司)
- 2024年新青岛版六年级上册(六三制)科学全册知识点
- 胰岛素皮下注射团体标准解读
- 2024年山东省烟台市中考地理试题卷(含答案解析)
- NB/T 11446-2023煤矿连采连充技术要求
- 全民国防教育知识竞赛考试题库-上(单选、多选题)
- 部编人教版三年级上册道德与法治全册教案
- 2024年全国保密教育线上培训考试试题库及答案
- 渗滤液处理运营服务保证措施(1)全文
- 2024年云南省楚雄新华书店限公司招聘8人历年(高频重点提升专题训练)共500题附带答案详解
- JT∕T 1132.2-2017 汽车维修电子健康档案系统 第2部分:数据采集技术要求
评论
0/150
提交评论