- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* 例5:2788二叉树 如图所示,由正整数1,2,3……组成了一颗二叉树。从某一个节点到根节点(编号为1)都有一条唯一的路径,例如从10到1的路径为(10,5,2,1),从4到1的路径为(4,2,1),从1到1的路径上只包括一个结点,路径为(1) 对两个结点x和y,假设它们到根结点1的路径分别是(x1,x2,…,1)和(y1,y2,…,1),显然x=x1,y=y1,则必然存在两个正整数i和j,使得从xi和yj开始,有xi=yj, xi+1=yj+1,….。 问题,给定x和y,求xi(也就是yi) * POJ2788解题思路 任意一个数,一直对2做整数除法,就能走到它的上层结点 设common(x,y)表示x和y最接近的公共子结点,则比较x和y的值可以得到三种情况: x=y:则common(x,y)=x=y; xy:则common(x,y)= common(x/2,y); xy:则common(x,y)= common(x,y/2); * 例6:POJ2694 逆波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的逆波兰表示法为+ 2 3。逆波兰表达式的优点是运算符之间不必有优先级关系,也不必用括号改变运算次序,例如(2 + 3) * 4的逆波兰表示法为* + 2 3 4。本题求解逆波兰表达式的值,其中运算符包括 + - * / 四个。 输入数据 输入为一行,其中运算符和运算数之间都用空格分隔,运算数是浮点数 * + 11.0 12.0 + 24.0 35.0 输出要求 输出为一行,表达式的值 1357.000000 * POJ2694 问题:递归函数如何构造? 递归函数如何定义? 递归函数的出口如何定义? 如何将递归函数定义与对输入数据的扫描结合起来? 1.???????? #include stdio.h 2.???????? #includemath.h 3.???????? double exp(){ 4.???????? char a[10]; 5.???????? scanf(%s, a); 6.???????? switch(a[0]){ 7.???????? case+: return exp( ) + exp( ); 8.???????? case-: return exp( ) - exp( ); 9.???????? case*: return exp( ) * exp( ); 10.???? case/: return exp( ) / exp( ); 11.???? default: return atof(a); 12.???? } 13.???? } 14.???? void main() 15.???? { 16.????????? double ans; 17.????????? ans=exp(); 18.????????? printf(%f, ans); 19.???????} * 例7:常规表达式计算 输入为四则运算表达式,仅由数字、+、-、*、/ 、(、) 组成,没有空格,要求求其值 * 表达式 项 + - 项 * / 因子 解题思想 表达式是个递归的定义: 因子 表达式 ( ) 数字 因此对于表达式可以进行递归分析处理 #include iostream.h #include string.h #include ctype.h double factor_value(); double term_value(); double expression_value(); main() { cout Enter an expression: ; cout expression_value() endl; } * 问题 如何定义三个函数? double factor_value(); double term_value(); double expression_value(); double expression_value() {//求一个表达式的值 double result = term_value();//求第一项的值 bool more = true; while( more) { char op = cin.peek();//从cin流中看一个 //字符,但不取出 if( op == + || op == - ) { cin.get(); int value = term_value(); if
您可能关注的文档
最近下载
- 《曾经》电影赏析.pptx VIP
- 钛合金薄壁鼓筒类零件加工变形控制.doc VIP
- 一种具有去除异味和抗菌功效的组合物及其制备方法与应用.pdf VIP
- 标准图集-15G107-1-装配式混凝土结构表示方法及示例(剪力墙结构).pdf VIP
- 公路统计年报要求及报表制度讲解.pptx
- TUCST007-2020 房屋建筑与市政基础设施工程施工安全风险评估技术标准.pdf VIP
- 临床营养病例讨论.ppt VIP
- 基层常见病的诊疗与管理题库答案-2025年华医网继续教育.docx VIP
- 中国心力衰竭诊断和治疗指南(2024)解读PPT课件.pptx VIP
- 世界水日-节约用水主题班会.ppt VIP
文档评论(0)