欢迎光临散文网 会员登陆 & 注册

华为OD机试-- 仿 LISP 运算

2023-10-14 20:36 作者:天生完美  | 我要投稿

题目

LISP 语言唯一的语法就是括号要配对。

形如 (OP P1 P2 …),括号内元素由单个空格分割。

其中第一个元素 OP 为操作符,后续元素均为其参数,参数个数取决于操作符类型。

注意:

参数 P1, P2 也有可能是另外一个嵌套的 (OP P1 P2 …) ,

当前 OP 类型为 add / sub / mul / div(全小写),分别代表整数的加减乘除法,

简单起见,所有 OP 参数个数均为 2 。

举例:

输入:(mul 3 -7)

输出:-21

输入:(add 1 2)

输出:3

输入:(sub (mul 2 4) (div 9 3))

输出:5

输入:(div 1 0)

输出:error

题目涉及数字均为整数,可能为负;

不考虑 32 位溢出翻转,计算过程中也不会发生 32 位溢出翻转,

除零错误时,输出 “error”,

除法遇除不尽,向下取整,即 3/2 = 1


思路

1:可以参考 逆波兰表达式 的解法。

2:核心还是数据结构:栈的使用方法。

  • 遇到数字,入栈

  • 遇到符号,弹出两个数,然后计算(栈底的元素在前,栈顶的元素在后面),将计算的结果入栈

Java 实现:https://renjie.blog.csdn.net/article/details/127972933

Python实现:https://renjie.blog.csdn.net/article/details/131024286

C++ 实现:https://renjie.blog.csdn.net/article/details/127322836

JavaScript实现:https://renjie.blog.csdn.net/article/details/131024296

C实现:https://renjie.blog.csdn.net/article/details/132006528


华为OD机试-- 仿 LISP 运算的评论 (共 条)

分享到微博请遵守国家法律