标题:仿LISP运算 | 时间限制:1秒 | 内存限制:262144K | 语言限制:不限
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
【华为OD机试真题 JAVA】仿LISP运算
于 2022-04-27 11:05:15 首次发布
该博客主要介绍了如何使用Java解决华为在线测评中的一道仿LISP运算问题。题目要求根据LISP语言的语法,处理加减乘除运算,并处理括号嵌套。通过解析输入的字符串,使用栈数据结构来存储数字和操作符,遇到闭括号时进行计算。题目中还特别提到了除零错误和向下取整的情况。示例展示了输入和预期输出,以及解题思路,包括利用栈处理表达式和通过字符判断运算类型。
摘要由CSDN通过智能技术生成