js递归实现字符串计算器,包含+-*/()

本文介绍了如何使用JavaScript递归地实现一个字符串计算器,能够处理包含括号、加减乘除运算的表达式。首先根据优先级处理括号内的算式,接着处理乘除法,再处理加减法。通过递归替换算式中的子表达式,最终得到计算结果。示例包括简单的加法、带乘除的表达式以及复杂带括号的算式。
摘要由CSDN通过智能技术生成

手机端上传待完善

思路: 将操作符按照优先级做处理,先获取最里面一层括号中的算式,拿到算式之后判断是否有乘除法,若有先计算乘除,用所得的值替换后再做加减法,无则直接计算加减。递归替换后拿到最终结果

 

举例说明

输入       输出

"1+1"        2

" 6 - 4 / 2 "     4

"2*(5+5*2)/3+(6/2+8)"     21

"(2+6*3+5-(3*14/7+2)*5)+3"   -12

 

characterCalculator(s) {

s = s.replace(/\s*/g,"")

if(s.indexOf('(') > -1 || s.indexOf(')')>-1){ var inter = this.getinter(s)

var news =s.replace(`(${inter})`,this.compute(inter)) return this.characterCalculator(news) } else { return this.compute(s) } }

 

getinter(s){ var result = s.match(/(\(+.+?\)+)/g)[0] var qu = result.slice(1,result.length-1) if(qu.indexOf('(') > -1 || qu.indexOf(')')>-1){ return this.g

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
递归实现表达式运算需要考虑一个算术表达式的各个元素以及运算符的优先级。下面是一个用C语言实现加减乘除模取模的递归解法的示例代码: ```c #include <stdio.h> int calculate(char *exp, int start); int parseNumber(char *exp, int *start) { int num = 0; while (exp[*start] >= '0' && exp[*start] <= '9') { num = num * 10 + (exp[*start] - '0'); (*start)++; } return num; } int calculate(char *exp, int start) { int num1 = parseNumber(exp, &start); while (exp[start] != '\0' && exp[start] != ')') { char op = exp[start++]; int num2 = parseNumber(exp, &start); switch (op) { case '+': num1 += num2; break; case '-': num1 -= num2; break; case '*': num1 *= num2; break; case '/': num1 /= num2; break; case '%': num1 %= num2; break; default: printf("Invalid operator\n"); return -1; } } return num1; } int main() { char expression[100]; printf("请输入要计算的表达式:"); scanf("%s", expression); int result = calculate(expression, 0); printf("计算结果为:%d\n", result); return 0; } ``` 以上代码中,函数`parseNumber`用于解析一个数值。函数`calculate`用于递归计算表达式,包括优先级高的乘除取模和优先级低的加减。在主函数中,用户输入一个表达式,然后调用`calculate`函数进行计算,并输出结果。 这个递归实现表达式运算的方法可以解析加减乘除取模运算,并且支持嵌套括号。但需要注意的是,这个实现有一些限制,例如不支持负数和浮点数的运算。如果需要更复杂的功能,可能需要更复杂的实现

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值