- 1、本文档共66页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
命名规则 在Linux/UNIX平台 习惯用function_name 本书采用Windows风格函数名命名 用大写字母开头、大小写混排的单词组合而成 FunctionName 变量名形式 “名词”或者“形容词+名词” 如oldValue与newValue等 函数名形式 “动词”或者“动词+名词”(动宾词组) 如GetMax()等 对函数接口进行注释说明 /* 函数功能: 实现××××功能 函数参数: 参数1,表示×× 参数2,表示×× 函数返回值: ××××× */ 返回值类型 函数名(形参表) { … return 表达式; } 挑战性的作业 挑战类型表示的极限 ——50位的n!计算? 大数的存储问题 Questions and answers 这个程序在Visual C++ 6.0环境下编译不会显示任何警告信息,但在Code:Blocks下编译会显示如下警告信息,提示程序第23行语句中的条件判断是永假的: warning: comparison of unsigned expression 0 is always false 递归函数(Recursive Function) unsigned long fact(unsigned int n) { if (n == 0 || n == 1) return 1; else return n * fact(n-1); } 基线情况(base case) 一般情况(general case) 无需考虑n0了 【例7.5】计算n!= n *(n-1)*(n-2)*…*1 递归函数(Recursive Function) 递归调用应该能够在有限次数内终止递归 递归调用若不加以限制,将无限循环调用 必须在函数内部加控制语句,仅当满足一定条件时,递归终止,称为条件递归 任何一个递归调用程序必须包括两部分 递归循环继续的过程 递归调用结束的过程 if (递归终止条件成立) return 递归公式的初值; else return 递归函数调用返回的结果值; n!=n×(n-1)! (n-1)!=(n-1)×(n-2)! (n-2)! … (n-3)! 5! … 4!=4×3! 3!=3×2! 2!=2×1! 1!=1 回推过程 递推过程 每个递归函数必须至少有一个基线条件 一般情况必须最终能简化为基线条件 递归层数太多易 导致栈空间溢出 后果很严重,程序被异常中止 fact(5)=5*fact(4)= 120 fact(4)= 4*fact(3)= 24 fact(3)= 3*fact(2)= 6 fact(2)= 2*fact(1)=2 fact(1)=1 main fact(5) fact(4) fact(3) fact(2) fact(1) 递归与迭代 用迭代(即循环)方法编写的阶乘函数 unsigned long Fact(unsigned int n) { unsigned long result = 1; unsigned int i; for (i = 1; i = n; i++) result *= i; return result; } 递归程序遵循了数学中对阶乘的定义 因此递归方法编写程序具有更清晰、可读性更好的优点 递归与迭代 1,1,2,3,5,8,...... long Fib(int n) { long f; if (n == 0) f = 0; else if (n == 1) f = 1; else f = Fib(n-1) + Fib(n-2); return f; } 1 5 4 3 2 3 2 2 1 1 0 1 0 1 0 计算fib(5)共需15次fib调用 【例7.6】计算Fibonacci数列 递归与迭代 优点: 从编程角度来看,比较直观、精炼,逻辑清楚 符合人
您可能关注的文档
- 企业消防安全知识培训课件.ppt
- 企业战略管理培训课件.pptx
- 情绪与压力管理培训教程.ppt
- 全国普通话水平测试 考前培训课件.ppt
- 全国中小学生系列武术操《英雄少年》动作分解.ppt
- 人教版二年级上册识字一课件.ppt
- C++课件多任务与多线程编程.ppt
- 人教版九年级美术下册课件:3.2 动漫形象设计2003.ppt
- 人教版语文二年级上册《识字4》.ppt
- C语言编程课件.pptx
- 2024-2025学年第一学期江西省鹰潭市七年级语文期中考试卷(含答案).pdf
- 山东省青岛市市北区2024-2025学年八年级下学期期末历史试题(含答案).pdf
- 深圳市高级中学2024-2025学年高一下学期期末考试政治试卷(含答案).pdf
- 天津市滨海新区2024-2025学年高一下学期7月期末检测政治试题(含答案).pdf
- 天津市四校联考2024-2025学年高一下学期7月期末考试政治试题(含答案).pdf
- 山东省德州市平原县 2024-2025学年八年级下学期7月期末考试道德与法治试卷(含答案).pdf
- 陕西省2025年普通高中学业水平合格性考试政治试卷(含答案).pdf
- 2025年河东区高一期末试卷——物理试卷.pdf
- 陕西省延安市志丹县2024-2025学年七年级下学期7月期末考试道德与法治试卷(含答案).pdf
- 深圳市高级中学2025届九年级下学期中考三模数学试卷(含答案).pdf
文档评论(0)