2603: 【栈】2023B-仿LISP运算
金币值:
1
时间限制:2.000 s
内存限制:128 M
正确:70
提交:230
正确率:30.43% 命题人:
题目描述
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
输入格式
输入为长度不超过 512 的字符串,用例保证了无语法错误
输出格式
输出计算结果或者"error"
输入样例 复制
(div 12 (sub 45 45))
输出样例 复制
error