- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
*/38 二叉树 1、问题描述 图1 满二叉树 */38 问题描述 如上图所示,由正整数1, 2, 3, ...组成了一棵无限大的二叉树。从某一个结点到根结点(编号是1的结点)都有一条唯一的路径,比如从10到根结点的路径是(10, 5, 2, 1),从4到根结点的路径是(4, 2, 1),从根结点1到根结点的路径上只包含一个结点1,因此路径就是(1)。 对于两个结点x和y,假设他们到根结点的路径分别是(x1, x2, ... ,1)和(y1, y2, ... ,1)(这里显然有x = x1,y = y1),那么必然存在两个正整数i和j,使得从xi 和 yj开始,有xi = yj , xi + 1 = yj + 1, xi + 2 = yj + 2,... 现在的问题就是,给定x和y,要求xi(也就是yj)。 */38 问题描述 输入格式 输入只有一行,包括两个正整数x 和y,这两个正整数都不大于1000。 输出要求 输出只有一个正整数xi。 输入样例 10 4 输出样例 2 */38 这个题目要求树上任意两个节点的最近公共子节点。分析这棵树的结构不难看出,不论奇数偶数,每个数对2 做整数除法,就走到它的上层结点。 我们可以每次让较大的一个数(也就是在树上位于较低层次的节点)向上走一个结点,直到两个结点相遇。 如果两个节点位于同一层,并且它们不相等,可以让其中任何一个先往上走,然后另一个再往上走,直到它们相遇。 设common(x, y)表示整数x 和y的最近公共子节点,那么,根据比较x 和y 的值,我们得到三种情况: (1) x 与y 相等,则common(x, y)等于x 并且等于y; (2) x 大于y,则common(x, y)等于common(x/2, y); (3) x 大于y,则common(x, y)等于common(x y/2); 2、解题思路 */38 3、参考程序 #include stdio.h int common(int x, int y) { if(x == y) return x; if(x y) return common(x / 2, y); return common(x, y / 2); } int main(void) { int m, n; scanf(%d%d, m, n); printf(%d\n, common(m, n)); return 0; } */38 波兰表达式 1、问题描述 波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3 的波兰表示法为+ 2 3。波兰表达式的优点是运算符之间不必有优先级关系,也不必用括号改变运算次序,例如(2 + 3) * 4 的波兰表示法为* + 2 3 4。本题求解波兰表达式的值,其中运算符包括 + - * / 四个。 */38 问题描述 输入数据 输入为一行,其中运算符和运算数之间都用空格分隔,运算数是浮点数 输出要求 输出为一行,表达式的值。 输入样例 * + 11.0 12.0 + 24.0 35.0 输出样例 1357.000000 */38 这个问题看上去有些复杂,如果只是简单地模拟计算步骤不太容易想清楚,但是如果用递归的思想就非常容易想清楚。让我们根据逆波兰表达式的定义进行递归求解。在递归函数中,针对当前的输入,有五种情况: (1) 输入是常数,则表达式的值就是这个常数; (2) 输入是’+’,则表达式的值是再继续读入两个表达式并计算出它们的值,然后将它们的值相加; (3) 输入是’-’; (4) 输入是’*’; (5) 输入是’/’; 后几种情况与2)相同,只是计算从’+’变成’-’,’*’,’/’。 2、解题思路 */38 3、参考程序 #include stdio.h #includemath.h double exp(void) { char a[10]; scanf(%s, a); switch(a[0]) { case+: return exp( ) + exp( ); case-: return exp( ) - exp( ); case*: return exp( ) * exp( ); case/: return exp( ) / exp( ); default: return atof(a); } } */38 int main(void) { double ans; ans = exp(); printf(%f, ans);
您可能关注的文档
最近下载
- 电厂化验考试试题及答案.doc VIP
- 【超星学习通】马克思主义基本原理(南开大学)尔雅章节测试网课答案.docx VIP
- 2024年河北省保定市竞秀区校联考中考一模语文试题.docx VIP
- 电厂化验培训课件.ppt VIP
- 冀教版小学英语六年级上册Unit 3 Lesson 13 Seasons 教学设计.docx
- 施工管理人员资质报审表.doc VIP
- 电厂化学水处理工试题及答案.docx VIP
- 南方电网标准材料模块(10kV各类型台架变物资的标准分包表).pdf VIP
- 江苏省南通市海门区2024-2025学年九年级上学期期末考试语文试题(B卷)(无答案).docx VIP
- 2024电厂化学-煤化验试题.pdf VIP
文档评论(0)