四则运算(递归) 痛定思痛。 2022-06-10 13:41 210阅读 0赞 ![20170820220200623][] ![20170820220224723][]![20170820220235319][] /* 1. 表达式由一个或多个项组成;(+ and -) 2. 一个项由一个或多个因子组成;(* and /) 3. 一个因子由一个或多个表达式或者一个整数组成。( ( and ) ) (2+3)*(5+7)+9/3 */ #include<iostream> #include<cstring> #include<cstdlib> using namespace std; int factor_value();//读入一个因子,并返回其值 int term_value();//读入一项,并返回其值 int expression_value();//读入一个表达式,并返回其值、 int main() { cout<<expression_value()<<endl; return 0; } int expression_value()//求一个表达式的值 //一个表达式只有两种可能:1. 只有一项;2. 有多项,通过加减相连 (项+-项) { int result = term_value();//求第一项的值 bool more = true; while(more)//有多项 { char op = cin.peek();//从输入流中看一个字符,不取走 if(op == '+' || op == '-') { cin.get();//从输入流中取走一个字符(即删除+或-) int value = term_value();//后一项 if(op == '+') result += value; else result -= value; } else more = false;//else break; } return result; } int term_value()//求一项的值 //项有两种可能:1. 只有一个因子 2. 有多个因子,用乘除相连 (因子*/因子) { int result = factor_value();//求一个因子的值 while(true) { char op = cin.peek();//看第一个字符是否为乘除 if( op == '*' || op == '/') { cin.get();//删除乘除号 int value = factor_value();//后一个因子的值 if( op == '*') result *= value; else result /= value; } else break; } return result; } int factor_value()//求一个因子的值。1. 一个数 2.(表达式) { int result = 0; char c = cin.peek(); if(c =='(') { cin.get();//删除左括号 result = expression_value(); cin.get();//删除右括号 } else//只有一个数时,把字符转为整数 { while(isdigit(c)) { result = 10 * result + c - '0'; cin.get(); c = cin.peek(); } } return result; } [20170820220200623]: /images/20220610/197c5bb2314b477c83a484795e19e89c.png [20170820220224723]: https://img-blog.csdn.net/20170820220224723 [20170820220235319]: /images/20220610/81a8512aafeb4d44b00a13e745d2b486.png
相关 递归---从台阶问题学习递归、递归优化和非递归 > 递归就是将大问题划分为若干个子问题,各个问题是嵌套关系,最小的那个问题的结果是已知的,大问题不断分解直到达到最小问题的过程叫做“递”,小问题的解释已知的,然后根据这个解回过 电玩女神/ 2023年06月17日 06:57/ 0 赞/ 107 阅读
相关 四则运算(递归) ![20170820220200623][] ![20170820220224723][]![20170820220235319][] / 1. 表达 痛定思痛。/ 2022年06月10日 13:41/ 0 赞/ 211 阅读
相关 递归 递归算法基本思想:找出递归子结构性质(原问题的解包含了子问题的解)、用子问题的解来递归定义原问题的解、找出递归终止条件。 示例: 例1 阶乘函数 阶乘函数可 ╰半橙微兮°/ 2022年06月09日 09:14/ 0 赞/ 374 阅读
相关 递归——线性递归与二分递归 递归 线性递归 例子1:数组求和 int sum( int A[], int n) { //数组求和算法:线性递归版 if 向右看齐/ 2022年05月21日 04:41/ 0 赞/ 419 阅读
相关 递归 递归优点:代码简单 代码量少 递归缺点:不易理解 用递归解决问题时,主要思路: 1.将一个大问题分解成子问题 2.子问题除了问题规模会变小,和原问题解决的思路是一 向右看齐/ 2022年05月03日 10:28/ 0 赞/ 290 阅读
相关 递归 1. public class HelloWorld \{ 2. public static void main(String\[\] args)\{ 3. // Sca 女爷i/ 2022年04月12日 10:50/ 0 赞/ 416 阅读
相关 递归 递归Recursion 递归要求 1. 递归一定要有退出条件,递归调用一定要执行到这个退出条件。没有退出条件的递归调用,就是无限调用 2 雨点打透心脏的1/2处/ 2022年02月19日 05:39/ 0 赞/ 372 阅读
相关 递归 问题描述 任何一个正整数都可以用2进制表示,例如:137的2进制表示为10001001。 将这种2进制表示写成2的次幂的和的形式,令次幂高的排在前面,可得到如下表达式:13 冷不防/ 2021年12月24日 08:43/ 0 赞/ 384 阅读
相关 递归 递归 递归就是一个函数直接或间接的调用自己.一般来说,递归需要有边界条件,递归前进段和递归返回段.当边界条件不满足的时,递归前进,当边界条件满足的时候,递归返回. 递归就 ﹏ヽ暗。殇╰゛Y/ 2021年12月12日 06:53/ 0 赞/ 312 阅读
相关 递归 递归只是让你解决方案更加清晰,并没有性能上的优势。实际上,在有些情况下,使用循环的性能更好。正如,在Stack Overflow 上,Leigh Caldwell 说了一句话: 男娘i/ 2021年09月13日 23:58/ 0 赞/ 442 阅读
还没有评论,来说两句吧...