华为OD机试真题——仿LISP运算(2025B卷:200分)Java/python/JavaScript/C/C++/GO最佳实现

在这里插入图片描述

2025 B卷 200分 题型

本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式;
并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析;
本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分享》

华为OD机试真题《仿LISP运算》:


文章快捷目录

题目描述及说明

Java

python

JavaScript

C++

C

GO


题目名称:仿LISP运算


知识点:字符串、栈操作(递归/逆波兰)、逻辑处理
时间限制:1秒
空间限制:256MB
限定语言:不限


题目描述

LISP 语言唯一的语法是括号必须配对。表达式形如 (OP P1 P2 …),括号内元素由单个空格分割。其中第一个元素 OP 为操作符,后续元素均为其参数,参数个数固定为 2。参数 P1P2 可能是整数或其他嵌套的表达式。

运算符规则

  • addsubmuldiv 分别代表加减乘除,运算结果为整数。
  • 除法规则:向下取整(如 3/2=1);若除数为 0,输出 error
  • 嵌套规则:表达式可多层嵌套,如 (sub (mul 2 4) (div 9 3))

输入描述

  • 输入为长度不超过 512 的字符串,用例保证无语法错误。

输出描述

  • 输出计算结果或 error
示例

输入

(add 1 (div -7 3))  

输出

-2  

说明
div 运算中 -7/3 向下取整为 -3add 结果为 1+(-3)=-2

输入

(div 12 (sub 45 45))  

输出

error  

说明
sub 结果为 0,导致除零错误。


Java

问题分析

我们需要解析类似LISP的嵌套表达式,并计算结果。运算符包括addsubmuldiv,每个运算符接受两个参数。除法需向下取整,若除数为0则输出error。表达式可能存在多层嵌套,例如(sub (mul 2 4) (div 9 3))

解题思路

  1. 递归解析:从最外层表达式开始,递归处理参数。若参数是嵌套表达式,则递归解析;若是数字,则直接转换。
  2. 分割参数:处理表达式时,正确分割操作符后的两个参数。参数可能是数字或嵌套表达式,需考虑括号嵌套的情况。
  3. 运算处理:根据操作符类型计算值,除法需判断除数是否为0,并正确取整。

代码实现

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);String input = scanner.nextLine().trim();try {int result = evaluate(input);System.out.println(result);} catch (Exception e) {System.out.println("error");}}private static int evaluate(String expr) throws Exception {if (expr.startsWith("(")) { // 判断是否是表达式return parse(expr);} else { // 否则为数字直接解析return Integer.parseInt(expr);}}private static int parse(String expr) throws Exception {// 去掉外层括号并去除首尾空格expr = expr.substring(1, expr.length() - 1).trim();int opEnd = expr.indexOf(' ');String op = expr.substring(0, opEnd); // 提取操作符String paramsStr = expr.substring(opEnd + 1).trim(); // 参数部分字符串// 分割参数为两个部分String[] params = splitParams(paramsStr);// 递归计算参数值int v1 = evaluate(params[0]);int v2 = evaluate(params[1]);// 根据操作符计算结果switch (op) {case "add":return v1 + v2;case "sub":return v1 - v2;case "mul":return v1 * v2;case "div":if (v2 == 0) {throw new ArithmeticException("Division by zero");}return Math.floorDiv(v1, v2);default:throw new IllegalArgumentException("Invalid operator: " + op);}}private static String[] splitParams(String expr) {List<String> tokens = new ArrayList<>();int depth = 0; // 括号深度int start = 0;for (int i = 0; i < expr.length(); i++) {char c = expr.charAt(i);if (c == '(') depth++;else if (c == ')') depth--;// 当括号深度为0且遇到空格时分割参数if (c == ' ' && depth == 0) {if (start < i) {tokens.add(expr.substring(start, i).trim());}start = i + 1;if (tokens.size() == 2) break; // 只需分割两个参数}}// 添加最后一个参数if (start <= expr.length()) {tokens.add(expr.substring(start).trim());}return new String[]{tokens.get(0), tokens.get(1)};}
}

代码解析

  1. 主函数 main

    • 读取输入,调用evaluate处理表达式,捕获异常输出error
  2. 函数 evaluate

    • 判断表达式类型:若以(开头则递归解析,否则直接转换为数字。
  3. 函数 parse

    • 去掉外层括号,分割操作符和参数。
    • 递归计算两个参数的值,执行对应运算。除法需检查除数是否为0。
  4. 函数 splitParams

    • 遍历字符串,根据括号深度分割参数。深度为0时遇到空格分割,确保正确处理嵌套表达式。

示例测试

  1. 输入1

    (add 1 (div -7 3))
    

    输出-2
    解析div -7 3得-3,add 1 -3结果为-2。

  2. 输入2

    (div 12 (sub 45 45))
    

    输出error
    解析sub 45 45得0,除法除数为0抛出异常。

  3. 输入3

    (mul (add 3 4) (sub 5 2))
    

    输出21
    解析add 3 4得7,sub 5 2得3,mul 7 3得21。

综合分析

  1. 时间复杂度

    • 取决于表达式深度,最坏情况为O(2^N)(N为嵌套层数),但题目限定输入长度≤512,可在1秒内处理。
  2. 空间复杂度

    • 递归调用栈深度为表达式嵌套层数,空间复杂度O(N)
  3. 正确性保障

    • 分割参数时严格处理括号嵌套,确保每个参数的完整性。
    • 除法检查除数为0,正确使用向下取整。
  4. 优势

    • 递归结构简洁,直接模拟表达式计算过程。
    • 灵活处理嵌套表达式,保证正确分割参数。
  5. 适用场景

    • 需要处理嵌套表达式的小规模问题,如编译器前端、公式解析等。

python

问题分析

我们需要解析类似LISP的递归嵌套表达式,并进行数学运算。表达式由括号包裹,运算符包括addsubmuldiv,每个操作符接受两个参数。参数可以是整数或嵌套表达式。运算过程中需处理除零错误和整除向下取整。

解题思路

  1. 递归解析:从外层表达式开始,递归处理每个参数。若参数是嵌套表达式,则递归解析;若是数字,直接转换。
  2. 参数分割:正确分割操作符后的两个参数,考虑嵌套表达式中的括号匹配。
  3. 运算处理:根据操作符计算值,除法检查除数是否为零,并确保整除向下取整。

代码实现

def evaluate(expr):expr = expr.strip()if expr.startswith('('):return parse(expr)else:return int(expr)def parse(expr):expr = expr.strip()# 去掉外层括号if expr.startswith('(') and expr.endswith(')'):expr = expr[1:-1].strip()# 分割操作符和参数部分op_end = expr.find(' ')op = expr[:op_end]params_str = expr[op_end+1:].strip()# 分割两个参数params = split_params(params_str)# 递归计算参数值a = evaluate(params[0])b = evaluate(params[1])# 执行运算if op == 'add':return

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/pingmian/82238.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建dummy

访客_dc1fc4 class Solution { public: int minSubArrayLen(int target, vector<int>& nums) { int left0;int right0;int n nums.size(); int sum0;int ans100001; for(right0;right<n;right) { sumnums[right]; //每次更新右端点之后&#xff0c;立即向右移动…

面向恶劣条件的道路交通目标检测----大创自用(当然你也可以在里面学到很多东西)

全部内容梳理 目标检测的两个任务&#xff1a; 预测标签 边界框 语义分割 实力分割 一个是类别 一个是实例级别 分类任务把每个图像当作一张图片看待 所有解决方法是先生成候选区域 再进行分类 置信度&#xff1a; 包括对类别和边界框预测的自信程度 输出分类和IOU分数的…

需求管理工具使用不当,如何优化?

要优化需求管理工具的使用&#xff0c;需从选择合适工具、规范使用流程、加强用户培训、统一数据结构、定期审查与优化使用配置五个方面着手。其中&#xff0c;选择合适工具是前提。错误的工具选择往往会导致项目沟通效率低、需求追踪失效甚至造成交付物偏离客户预期。因此&…

openwrt虚拟机安装调试

分类 lienol lean immortalwrt 一、获取固件 &#xff08;1&#xff09;下载地址 1.官网构建下载 OpenWrt Firmware Selector 官网 OpenWrt Firmware Selector 2.第三方构建网站 ImmortalWrt Firmware Selector ImmortalWrt Firmware Selector 3.第三方构建下载 ht…

Apache OFBiz 17.12.01 的远程命令执行漏洞 -Java 反序列化 + XML-RPC 请求机制

目录 漏洞原理 &#x1f3af; 一、漏洞背景&#xff08;CVE-2020-9496&#xff09; ⚙️ 二、攻击原理简述 &#x1f9f1; 三、完整攻击流程步骤详解 &#x1f50e; 1. 信息收集 &#x1f6e0;️ 2. 工具准备 &#x1f9ea; 3. 构造初始 payload&#xff1a;下载恶意脚本…

最好用的wordpress外贸主题

产品展示独立站wordpress主题 橙色的首页大banner外贸英文wordpress主题&#xff0c;适合用于产品展示型的外贸网站。 https://www.jianzhanpress.com/?p8556 Machine机器wordpress模板 宽屏简洁实用的wordpress外贸建站模板&#xff0c;适合工业机器生产、加工、制造的外贸…

Q1:Go协程、Channel通道 被close后,读会带来什么问题?

在 Go 语言中&#xff0c;Channel&#xff08;通道&#xff09;关闭后读取的行为是一个常见但需要谨慎处理的问题。以下是详细的分析和注意事项&#xff1a; 1. 关闭 Channel 后读取的行为 (1) 读取已关闭的 Channel 剩余数据仍可读取&#xff1a; 关闭 Channel 后&#xff0…

【AI Study】第三天,Python基础 - 同NumPy类似的类库

学习计划&#xff1a;AI Study&#xff0c;学习计划源码地址&#xff1a;https://github.com/co-n00b/AI-Study.git 2025-05-23 在学习NumPy的过程中&#xff0c;除了了解NumPy之外&#xff0c;我们也对比看看其他类似的类库都有什么&#xff1f;各自的优缺点是什么&#xff1…

基于aspnet,微信小程序,mysql数据库,在线微信小程序汽车故障预约系统

详细视频:【基于aspnet,微信小程序,mysql数据库,在线微信小程序汽车故障预约系统。-哔哩哔哩】 https://b23.tv/zfqLWPV

人工智能100问☞第32问:什么是迁移学习?

目录 一、通俗解释 二、专业解析 三、权威参考 迁移学习就是让AI把在一个任务中学到的本事&#xff0c;拿来加速另一个任务的学习&#xff0c;实现“举一反三”。 一、通俗解释 想象你已经学会了打乒乓球&#xff0c;现在去学打网球&#xff0c;是不是会学得更快&#xff…

Linux之概述和安装vm虚拟机

文章目录 操作系统概述硬件和软件操作系统常见操作系统 初识LinuxLinux的诞生Linux内核Linux发行版 虚拟机介绍虚拟机 VMware WorkStation安装虚拟化软件VMware WorkStation 安装查看VM网络连接设置VM存储位置 在VMware上安装Linux(发行版CentOS7)安装包获取CentOS7 安装 Mac系…

两个mysql的maven依赖要用哪个?

背景 <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId> </dependency>和 <dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId> &l…

复杂项目中通过使用全局变量解决问题的思维方式

最近接手了一个公司的老系统的PHP项目&#xff0c;里面的代码比较混乱&#xff0c;排查解决了一个问题&#xff0c;决定将这个思路记录下来&#xff0c;希望能帮助更多的人。 其中一部分的代码信息如下&#xff1a; 备注&#xff1a;为了避免公司的相关数据信息暴露&#xff0…

V9数据库替换授权

文章目录 环境文档用途详细信息 环境 系统平台&#xff1a;Linux x86-64 Red Hat Enterprise Linux 7 版本&#xff1a;9.0 文档用途 1、本文档用于指导V9数据库替换授权。 2、V9数据库授权文件为license.dat。 详细信息 1、上传新的授权文件到服务器并修改授权文件属主为…

初识 Flask 框架

目录 1. Flask 框架概述 1.1 安装 Flask 1.2 创建你的第一个 Flask 应用 1.3 运行 Flask 应用 2. Flask 路由与视图函数 2.1 动态路由 2.2 支持多种 HTTP 请求方法 2.3 使用 Jinja2 模版渲染 HTML 2.5 模版继承与块 3. Flask 表单处理与用户输入 3.1 安装 Flask-WTF …

《深入剖析:Python自动化测试框架之unittest与pytest》

unittest作为Python标准库的一部分&#xff0c;犹如一位沉稳可靠的“老工匠”&#xff0c;默默为无数项目提供着坚实的测试基础。它诞生于Python社区长期的实践沉淀&#xff0c;拥有一套标准化的测试体系&#xff0c;就像一套精密的仪器&#xff0c;各个部件各司其职。 unitte…

【Python 命名元祖】collections.namedtuple 学习指南

&#x1f4da; collections.namedtuple 学习指南 命名元组&#xff08;namedtuple&#xff09;是 Python collections 模块中一种增强型元组&#xff0c;支持通过字段名访问元素&#xff0c;同时保持元组的内存效率和不可变性。 一、基础用法 1. 定义命名元组 from collectio…

iOS知识复习

block原理 OC block 是个结构体&#xff0c;内部有个一个结构体成员 专门保存 捕捉对象 Swift闭包 是个函数&#xff0c;捕获了全局上下文的常量或者变量 修改数组存储的内容&#xff0c;不需要加_block,修改数组对象本身时需要 weak原理 Weak 哈希表 &#xff08;散列表&a…

手眼标定:九点标定、十二点标定、OpenCV 手眼标定

因为一直使用6轴协作机器人&#xff0c;且主要应用是三维视觉&#xff0c;平常的手眼标定基本都是基于OpenCV来计算的&#xff0c;听说有九点标定和十二点标定&#xff0c;顺便了解下。 目录 1.九点标定1.1 基本原理1.2 关于最小二乘法1.3 具体示例 2.十二点标定3.OpenCV 手眼标…

CSS之元素定位

元素定位 一、什么是元素定位 元素定位&#xff08;CSS Positioning&#xff09; 是指通过CSS的 position 属性控制HTML元素在页面中的布局方式。它决定了元素如何相对于其父元素、视口或其他元素进行位置调整。 CSS的 position 属性用于控制元素在页面上的定位方式&#xff…