華為OD機試真題——文件目錄大小(2025 A卷:100分)Java/python/JavaScript/C++/C語言/GO六種語言最佳實現

在這里插入圖片描述

2025 A卷 100分 題型

本文涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、測試用例以及綜合分析;
并提供Java、python、JavaScript、C++、C語言、GO六種語言的最佳實現方式!

2025華為OD真題目錄+全流程解析/備考攻略/經驗分享

華為OD機試真題《文件目錄大小》:


目錄

    • 題目名稱:文件目錄大小
      • 題目描述
      • 示例
    • Java
      • 問題分析
      • 解決思路
      • 代碼實現
      • 代碼詳細解析
      • 綜合分析
    • python
      • 題目分析
      • 解決思路
      • Python 代碼實現
      • 代碼逐行注釋
      • 綜合分析
      • 示例測試
        • 輸入1:
        • 輸入2:
      • 總結
    • JavaScript
      • 題目分析
      • 解決思路
      • JavaScript 代碼實現
      • 代碼逐行注釋
      • 綜合分析
      • 示例測試
        • 輸入1:
        • 輸入2:
      • 總結
    • C++
      • 題目分析
      • 解決思路
      • C++ 代碼實現
      • 代碼逐行解析
      • 綜合分析
      • 示例測試
        • 輸入1:
        • 輸入2:
      • 總結
    • C語言
      • 題目分析
      • 解決思路
      • C 代碼實現
      • 代碼逐行解析
      • 綜合分析
      • 示例測試
        • 輸入1:
        • 輸入2:
      • 總結
    • GO
      • 題目分析
      • 解決思路
      • Go 代碼實現
      • 代碼逐行注釋
      • 綜合分析
      • 示例測試
        • 輸入1:
        • 輸入2:
      • 總結

題目名稱:文件目錄大小


知識點:字符串、棧操作(DFS)、邏輯處理
時間限制:1秒
空間限制:256MB
限定語言:不限


題目描述

一個文件目錄的數據格式為:目錄id,本目錄中文件大小,(子目錄id列表)。其中:

  • 目錄id全局唯一,取值范圍為[1, 200]
  • 本目錄文件大小范圍為[1, 1000]
  • 子目錄id列表個數為[0, 10]

輸入描述

  • 第一行:兩個整數 MN,表示目錄個數和待查詢的目錄id(1 ≤ M ≤ 1001 ≤ N ≤ 200)。
  • 后續 M 行:每行描述一個目錄,格式為 目錄id 文件大小 (子目錄列表),例如 1 20 (2,3)

輸出描述

  • 待查詢目錄及其所有子目錄的文件大小之和。

示例

輸入1

3 1  
3 15 ()  
1 20 (2)  
2 10 (3)  

輸出1

45  

輸入2

4 2  
4 20 ()  
5 30 ()  
2 10 (4,5)  
1 40 ()  

輸出2

60  

Java

問題分析

這道題目要求計算指定目錄及其所有子目錄的文件大小總和。我們可以將其視為一個樹形結構問題,每個目錄作為節點,子目錄作為子節點。以下是詳細的解決思路和代碼實現。

解決思路

  1. 輸入解析:首先讀取目錄數目M和目標目錄N,然后逐行解析每個目錄的信息,包括目錄ID、文件大小和子目錄列表。
  2. 數據結構:使用兩個哈希表分別存儲目錄的大小和子目錄列表,便于快速查找。
  3. 遞歸計算:從目標目錄開始,遞歸遍歷所有子目錄,累加文件大小總和。

代碼實現

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);// 讀取目錄個數M和待查詢的目錄id Nint M = scanner.nextInt();int N = scanner.nextInt();scanner.nextLine(); // 跳過剩余換行符// 使用哈希表存儲目錄的大小和子目錄列表Map<Integer, Integer> sizeMap = new HashMap<>();Map<Integer, List<Integer>> childrenMap = new HashMap<>();for (int i = 0; i < M; i++) {String line = scanner.nextLine().trim();// 使用正則表達式按一個或多個空格分割行數據String[] parts = line.split("\\s+");int dirId = Integer.parseInt(parts[0]);int size = Integer.parseInt(parts[1]);String childrenStr = parts[2]; // 子目錄列表部分,如"(2,3)"// 處理子目錄字符串,提取子目錄idchildrenStr = childrenStr.substring(1, childrenStr.length() - 1) // 去掉括號.trim(); // 去除可能存在的首尾空格List<Integer> children = new ArrayList<>();if (!childrenStr.isEmpty()) { // 處理非空子目錄列表String[] childIds = childrenStr.split(",");for (String childId : childIds) {childId = childId.trim(); // 去除每個子目錄id的前后空格if (!childId.isEmpty()) {children.add(Integer.parseInt(childId));}}}// 將解析后的數據存入哈希表sizeMap.put(dirId, size);childrenMap.put(dirId, children);}// 計算目標目錄及其所有子目錄的總大小int totalSize = calculateTotalSize(N, sizeMap, childrenMap);System.out.println(totalSize);}// 遞歸計算目錄總大小private static int calculateTotalSize(int dirId, Map<Integer, Integer> sizeMap, Map<Integer, List<Integer>> childrenMap) {// 獲取當前目錄的大小int sum = sizeMap.get(dirId);// 遍歷所有子目錄,遞歸累加for (int childId : childrenMap.get(dirId)) {sum += calculateTotalSize(childId, sizeMap, childrenMap);}return sum;}
}

代碼詳細解析

  1. 輸入處理

    • 使用Scanner讀取輸入,第一行讀取M和N。
    • scanner.nextLine()用于跳過換行符,確保后續讀取正確。
  2. 數據結構初始化

    • sizeMap存儲目錄ID到文件大小的映射。
    • childrenMap存儲目錄ID到子目錄列表的映射。
  3. 解析目錄信息

    • 每行按空格分割為三部分:目錄ID、文件大小、子目錄列表字符串。
    • 處理子目錄字符串:去除括號和空格,分割后轉為整數列表。
  4. 遞歸計算總大小

    • 遞歸函數calculateTotalSize從目標目錄開始,累加當前目錄大小及其所有子目錄的總大小。

綜合分析

  1. 高效的數據結構:哈希表提供O(1)時間復雜度的查找,適合快速訪問目錄信息。
  2. 遞歸的簡潔性:遞歸自然契合樹形結構,代碼簡潔易懂,適合處理嵌套子目錄。
  3. 健壯性:正確處理輸入中的各種格式(如空格、空子目錄列表),確保解析準確。
  4. 時間復雜度:每個目錄僅訪問一次,總時間復雜度為O(M),滿足題目限制。

通過這種方法,能清晰理解目錄結構的遍歷和遞歸計算過程,確保正確高效地解決問題。


python

題目分析

題目要求計算指定目錄及其所有子目錄的文件大小總和。每個目錄信息以 目錄id 文件大小 (子目錄列表) 的格式給出,我們需要從輸入中解析這些信息,并遞歸地累加目標目錄及其所有子目錄的文件大小。


解決思路

  1. 輸入解析:讀取目錄數量 M 和目標目錄 N,解析每個目錄的信息。
  2. 數據結構:用字典存儲目錄的文件大小和子目錄列表。
  3. 遞歸計算:從目標目錄開始,遞歸遍歷所有子目錄,累加文件大小總和。

Python 代碼實現

def main():import sys# 讀取輸入lines = [line.strip() for line in sys.stdin if line.strip()]# 解析 M 和 NM, N = map(int, lines[<

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/83189.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/83189.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/83189.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

qwen 2.5 并行計算機制:依靠 PyTorch 和 Transformers 庫的分布式能力

qwen 2.5 并行計算機制:依靠 PyTorch 和 Transformers 庫的分布式能力 完整可運行代碼: import torch import torch.nn.functional as F from transformers

TIDB創建索引失敗 mkdir /tmp/tidb/tmp_ddl-4000/1370: no such file or directory.

TIDB創建索引失敗&#xff1a;解決“mkdir /tmp/tidb/tmp_ddl-4000/1370: no such file or directory”問題 在使用 TIDB 數據庫時&#xff0c;我們有時會遇到創建索引失敗的問題。常見的錯誤信息為&#xff1a; mkdir /tmp/tidb/tmp_ddl-4000/1370: no such file or directo…

華為OD機試真題—— 最少數量線段覆蓋/多線段數據壓縮(2025A卷:100分)Java/python/JavaScript/C++/C語言/GO六種最佳實現

2025 A卷 100分 題型 本文涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、測試用例以及綜合分析; 并提供Java、python、JavaScript、C++、C語言、GO六種語言的最佳實現方式! 2025華為OD真題目錄+全流程解析/備考攻略/經驗分享 華為OD機試真題《最少數量線段覆蓋/多線段數…

EasyRTC嵌入式音視頻實時通話SDK助力AI與IoT智能硬件打造音視頻交互多場景應用

一、引言? 在數字化浪潮下&#xff0c;AI與IoT深度融合重塑智能硬件產業。實時音視頻通信是智能硬件交互的核心&#xff0c;其性能關乎用戶體驗與場景拓展。EasyRTC嵌入式音視頻實時通話SDK基于WebRTC技術&#xff0c;以輕量、易擴展的特性&#xff0c;為AI與IoT智能硬件融合…

第十四章 MQTT訂閱

系列文章目錄 系列文章目錄 第一章 總體概述 第二章 在實體機上安裝ubuntu 第三章 Windows遠程連接ubuntu 第四章 使用Docker安裝和運行EMQX 第五章 Docker卸載EMQX 第六章 EMQX客戶端MQTTX Desktop的安裝與使用 第七章 EMQX客戶端MQTTX CLI的安裝與使用 第八章 Wireshark工具…

【第4章 圖像與視頻】4.4 離屏 canvas

文章目錄 前言為什么要使用 offscreenCanvas為什么要使用 OffscreenCanvas如何使用 OffscreenCanvas第一種使用方式第二種使用方式 計算時長超過多長時間適合用Web Worker 前言 在 Canvas 開發中&#xff0c;我們經常需要處理復雜的圖形和動畫&#xff0c;這些操作可能會影響頁…

Go語言事件總線EventBus本地事件總線系統的完整實現框架

在Go語言中&#xff0c;EventBus是一種非常有用的工具&#xff0c;它通過事件驅動的編程方式&#xff0c;幫助開發者實現組件之間的解耦&#xff0c;提高代碼的可維護性和擴展性。 背景 軟件架構的發展需求&#xff1a;隨著軟件系統的規模和復雜度不斷增大&#xff0c;傳統的緊…

Go語言接口:靈活多態的核心機制

引言 Go語言的接口系統是其??面向對象編程??的核心&#xff0c;它摒棄了傳統語言的類繼承體系&#xff0c;采用獨特的??隱式實現??和??鴨子類型??設計。這種設計使得Go接口既靈活又強大&#xff0c;成為構建松耦合系統的關鍵工具。本文將深入剖析Go接口的實現機制…

DeviceNET轉EtherCAT網關:醫院藥房自動化的智能升級神經中樞

在現代醫院藥房自動化系統中&#xff0c;高效、精準、可靠的設備通信是保障患者用藥安全與效率的核心。當面臨既有支持DeviceNET協議的傳感器、執行器&#xff08;如藥盒狀態傳感器、機械臂限位開關&#xff09;需接入先進EtherCAT高速實時網絡時&#xff0c;JH-DVN-ECT疆鴻智能…

android實現使用RecyclerView詳細

顯示頁面代碼&#xff1a;activity_category_inventory.xml代碼&#xff1a; <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android" xmlns:app"http://schemas.and…

【SpringBoot實戰】優雅關閉服務

文章目錄 一、什么是優雅關閉&#xff1f;二、優雅關閉的核心步驟三、SpringBoot優雅關閉實現四、關鍵注意事項1. 超時時間必須配置2. 信號支持局限性3. 特殊請求處理 五、底層實現原理六、總結 一、什么是優雅關閉&#xff1f; 優雅關閉&#xff08;Graceful Shutdown&#x…

C++哈希表:unordered系列容器詳解

本節目標 1.unordered系列關聯式容器 2.底層結構 3.模擬實現 4.哈希的應用 5.海量數據處理面試題 unordered系列關聯式容器 在c98中&#xff0c;STL提供了底層為紅黑樹結構的一系列關聯式容器&#xff0c;在查詢時效率可以達到logN&#xff0c;即最差的情況下需要比較紅…

java操作服務器文件(把解析過的文件遷移到歷史文件夾地下)

第一步導出依賴 <dependency><groupId>org.apache.sshd</groupId><artifactId>sshd-core</artifactId><version>2.13.0</version></dependency> 第二步寫代碼 public void moveFile( List<HmAnalysisFiles> hmAnalys…

Oracle OCP認證的技術定位怎么樣?

一、引言&#xff1a;Oracle OCP認證的技術定位? Oracle Certified Professional&#xff08;OCP&#xff09;認證是數據庫領域含金量最高的國際認證之一&#xff0c;其核心價值在于培養具備企業級數據庫全生命周期管理能力的專業人才。隨著數字化轉型加速&#xff0c;OCP認證…

TK海外搶單源碼/指定卡單

? 搶單源碼&#xff0c;有指定派單&#xff0c;打針&#xff0c;這套二改過充值跳轉客服 前端vue 后端php 兩端分離 可二開 可以指定卡第幾單&#xff0c;金額多少&#xff0c; 前后端開源 PHP7.2 MySQL5.6 前端要www.域名&#xff0c;后端要admin.域名 前端直接靜態 偽靜…

遠程線程注入

注入簡單來說就是讓別人的程序執行 你想要讓他執行的dll #include<iostream> #include<Windows.h> using namespace std;char szBuffer[] "C:\\Users\\20622\\source\\repos\\Dll1\\Debug\\test.dll"; //dll路徑void RemoteThreadInject(DWORD Pid,PCH…

【Java實戰】集合排序方法與長度獲取方法辨析(易懂版)

一、排序方法 1. 對List排序的兩種方式 方式一Collections.sort() List<Integer> numbers Arrays.asList(3,1,4,2); Collections.sort(numbers); // 直接修改原list → [1,2,3,4]方式二&#xff1a;list.sort()&#xff08;Java8推薦&#xff09; List<String>…

企業級安全實踐:SSL/TLS 加密與權限管理(一)

引言 ** 在數字化轉型的浪潮中&#xff0c;企業對網絡的依賴程度與日俱增&#xff0c;從日常辦公到核心業務的開展&#xff0c;都離不開網絡的支持。與此同時&#xff0c;網絡安全問題也日益嚴峻&#xff0c;成為企業發展過程中不可忽視的重要挑戰。 一旦企業遭遇網絡安全事…

Java 大視界 -- Java 大數據在智能醫療影像數據壓縮與傳輸優化中的技術應用(227)

&#x1f496;親愛的朋友們&#xff0c;熱烈歡迎來到 青云交的博客&#xff01;能與諸位在此相逢&#xff0c;我倍感榮幸。在這飛速更迭的時代&#xff0c;我們都渴望一方心靈凈土&#xff0c;而 我的博客 正是這樣溫暖的所在。這里為你呈上趣味與實用兼具的知識&#xff0c;也…

Python編程基礎(一) | 變量和簡單數據類型

引言&#xff1a;很久沒有寫 Python 了&#xff0c;有一點生疏。這是學習《Python 編程&#xff1a;從入門到實踐&#xff08;第3版&#xff09;》的課后練習記錄&#xff0c;主要目的是快速回顧基礎知識。 練習1&#xff1a; 簡單消息 將一條消息賦給變量&#xff0c;并將其…