首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试
MPA考试 | 中科院
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT
新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证
华为认证 | Java认证
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格
报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师
人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平
驾驶员 | 网络编辑
卫生资格 | 执业医师 | 执业药师 | 执业护士
会计从业资格考试会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师
注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师
质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师
设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师
城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏
您现在的位置: 考试吧(Exam8.com) > 计算机等级考试 > 计算机二级 > C语言 > 复习资料 > 正文

2010年计算机等级考试二级C语言教程:第五章

来源:考试吧Exam8.com) 2010-5-25 17:58:36 考试吧:中国教育培训第一门户 模拟考场
考试吧提供了2010年计算机等级考试二级C语言教程,帮助考生备战2010年计算机等级考试

  程序中给出的函数ff是一个递归函数。主函数调用ff 后即进入函数ff执行,如果n<0,n==0或n=1时都将结束函数的执行,否则就递归调用ff函数自身。由于每次递归调用的实参为n-1,即把n-1 的值赋予形参n,最后当n-1的值为1时再作递归调用,形参n的值也为1,将使递归终止。然后可逐层退回。下面我们再举例说明该过程。 设执行本程序时输入为5, 即求 5!。在主函数中的调用语句即为y=ff(5),进入ff函数后,由于n=5,不等于0或1,故应执行f=ff(n-1)*n,即f=ff(5-1)*5。该语句对ff作递归调用即ff(4)。 逐次递归展开如图5.3所示。进行四次递归调用后,ff函数形参取得的值变为1,故不再继续递归调用而开始逐层返回主调函数。ff(1)的函数返回值为1,ff(2)的返回值为1*2=2,ff(3)的返回值为2*3=6,ff(4) 的返

  回值为6*4=24,最后返回值ff(5)为24*5=120。

  例5. 9也可以不用递归的方法来完成。如可以用递推法,即从1开始乘以2,再乘以3…直到n。递推法比递归法更容易理解和实现。但是有些问题则只能用递归算法才能实现。典型的问题是Hanoi塔问题。

  [例5.10]Hanoi塔问题

  一块板上有三根针,A,B,C。A针上套有64个大小不等的圆盘, 大的在下,小的在上。如图5.4所示。要把这64个圆盘从A针移动C针上,每次只能移动一个圆盘,移动可以借助B针进行。但在任何时候,任何针上的圆盘都必须保持大盘在下,小盘在上。求移动的步骤。

  本题算法分析如下,设A上有n个盘子。

  如果n=1,则将圆盘从A直接移动到C。

  如果n=2,则:

  1.将A上的n-1(等于1)个圆盘移到B上;

  2.再将A上的一个圆盘移到C上;

  3.最后将B上的n-1(等于1)个圆盘移到C上。

  如果n=3,则:

  A. 将A上的n-1(等于2,令其为n`)个圆盘移到B(借助于C),

  步骤如下:

  (1)将A上的n`-1(等于1)个圆盘移到C上,见图5.5(b)。

  (2)将A上的一个圆盘移到B,见图5.5(c)

  (3)将C上的n`-1(等于1)个圆盘移到B,见图5.5(d)

  B. 将A上的一个圆盘移到C,见图5.5(e)

  C. 将B上的n-1(等于2,令其为n`)个圆盘移到C(借助A),

  步骤如下:

  (1)将B上的n`-1(等于1)个圆盘移到A,见图5.5(f)

  (2)将B上的一个盘子移到C,见图5.5(g)

  (3)将A上的n`-1(等于1)个圆盘移到C,见图5.5(h)。

  到此,完成了三个圆盘的移动过程。

 << 上一页  11 12 13 14 15 16 17 18 19 20  ... 下一页  >> 
  相关推荐:计算机等考二级C语言备考:C语言/C++编译过程
       2010年计算机等级考试二级公共基础知识教程
       考试吧:2010年计算机等考二级C预测题汇总
       全国计算机等考二级C语言:程序设计实战汇总
文章搜索
版权声明:如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系800@exam8.com,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。