華為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
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/82238.shtml
英文地址,請注明出處:http://en.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…