華為OD機試真題——猴子吃桃/愛吃蟠桃的孫悟空(2025B卷:200分)Java/python/JavaScript/C++/C語言/GO六種最佳實現

在這里插入圖片描述

2025 B卷 200分 題型

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

本文收錄于專欄:《2025華為OD真題目錄+全流程解析/備考攻略/經驗分享》

華為OD機試真題《猴子吃桃/愛吃蟠桃的孫悟空》:


目錄

    • 題目名稱:猴子吃桃/愛吃蟠桃的孫悟空
      • 題目描述
    • Java
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • python
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • JavaScript
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • C++
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • C語言
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析
    • GO
      • 問題分析
      • 解題思路
      • 代碼實現
      • 代碼詳細解析
      • 示例測試
      • 綜合分析


題目名稱:猴子吃桃/愛吃蟠桃的孫悟空


知識點:二分查找、邏輯處理
時間限制:1秒
空間限制:256MB
語言限制:不限


題目描述

孫悟空喜歡吃蟠桃,一天他趁守衛不在偷吃蟠桃。已知蟠桃園有 N 棵桃樹,每棵樹上的蟠桃數量用數組表示,守衛將在 H 小時后回來。
孫悟空可以決定吃桃速度 K(個/小時),每小時選一棵樹吃掉 K 個。若樹上桃子少于 K,則全部吃掉,且這一小時內不再吃其他樹。
求孫悟空在 H 小時內吃完所有蟠桃的 最小速度 K(整數),若無法完成則返回 0。

輸入描述

  • 第一行:N 個正整數,表示每棵桃樹上的蟠桃數量,空格分隔。
  • 第二行:一個正整數 H,表示守衛離開的時間。
  • 數據范圍:0 < N < 100000 < H < 10000,每棵樹上的蟠桃數量為正整數。

輸出描述

  • 輸出最小速度 K,無解或輸入異常時輸出 0。

示例
輸入:

2 3 4 5  
4  

輸出:

5  

說明:以速度 5 可在 4 小時內吃完所有桃子。


Java

問題分析

我們需要找到孫悟空在H小時內吃完所有蟠桃的最小速度K。每小時他可以選擇一棵樹吃掉K個,若樹上的桃子少于K則全部吃掉,且這一小時內不再吃其他樹。如果無法在H小時內吃完,返回0。


解題思路

  1. 輸入驗證:確保輸入的桃樹數量合法且H為正整數。
  2. 邊界確定:最小速度K為1,最大K為桃樹中桃子最多的數量。
  3. 二分查找:在可能的K范圍內,通過二分查找找到滿足條件的最小K。
  4. 時間計算:對于每個K,計算吃完所有桃子所需的總時間,并與H比較。

代碼實現

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);// 讀取桃樹數組String[] firstLine = scanner.nextLine().split(" ");List<Integer> list = new ArrayList<>();try {for (String s : firstLine) {int num = Integer.parseInt(s);if (num <= 0) { // 桃子必須為正整數System.out.println(0);return;}list.add(num);}} catch (NumberFormatException e) { // 輸入異常處理System.out.println(0);return;}if (list.isEmpty()) { // 無桃樹情況System.out.println(0);return;}int[] piles = list.stream().mapToInt(i -> i).toArray();// 讀取Hif (!scanner.hasNextInt()) { // 檢查H是否為整數System.out.println(0);return;}int H = scanner.nextInt();if (H <= 0) { // H必須為正整數System.out.println(0);return;}// 檢查H是否足夠(至少需要N小時)if (H < piles.length) {System.out.println(0);return;}// 二分查找最小速度Kint left = 1;int right = Arrays.stream(piles).max().getAsInt();int ans = 0;while (left <= right) {int mid = left + (right - left) / 2;int time = calculateTime(piles, mid);if (time <= H) { // 時間足夠,嘗試找更小的Kans = mid;right = mid - 1;} else { // 時間不足,需要增大Kleft = mid + 1;}}System.out.println(ans);}// 計算以速度K吃完所有桃子的總時間private static int calculateTime(int[] piles, int K) {int total = 0;for (int pile : piles) {total += (pile + K - 1) / K; // 向上取整的技巧}return total;}
}

代碼詳細解析

  1. 輸入處理

    • 使用Scanner讀取輸入,分割成字符串數組。
    • 將字符串轉換為整數,處理非法輸入(如非數字、非正數)。
  2. 輸入驗證

    • 檢查桃樹數組是否為空。
    • 檢查H是否為正整數,且H不小于桃樹數量。

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

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

相關文章

【Java學習筆記】單例設計模式

單例設計模式 單例模式介紹 1. 所謂類的單例設計模式&#xff0c;就是采取一定的方法保證在整個的軟件系統中 &#xff08;1&#xff09;對某個類只能存在一個對象實例 &#xff08;2&#xff09;并且該類只提供一個取得對象實例的方法 2. 分類&#xff08;兩種方式&#xf…

vue實例 與組件實例

vue實例 與組件實例流程圖 &#x1f9e9; 基本解釋 ? Vue 實例 Vue 實例是通過 new Vue({…}) 創建的對象&#xff0c;是整個應用的根節點。 const vm new Vue({el: #app,data: { msg: Hello Vue } });是整個應用的起點。只有一個根 Vue 實例&#xff08;通常&#xff09;…

Hive 分桶(Bucketing)深度解析:原理、實戰與核心概念對比

一、分桶的意義&#xff1a;比分區更細的粒度管理 1.1 解決分區數據不均勻問題 分區的局限性&#xff1a;分區基于表外字段&#xff08;如時間字段&#xff09;劃分數據&#xff0c;但可能導致部分分區數據量過大&#xff0c;部分過小&#xff0c;無法進一步細化。 分桶的定…

pytest+allure+allure-pytest 報告輸出遇到的問題匯總

文章目錄 前言問題一&#xff1a;module allure has no attribute severity_level問題二&#xff1a;ERROR:file or directory not found: ‐vs問題三&#xff1a;生成的 html 報告是空的&#xff0c;明明有測試用例執行完成&#xff0c;但報告沒有顯示數據 前言 pytestallure…

升級node@22后運行npm install報錯 distutils not found

從node20升級到node22后&#xff0c;在運行 npm install 的時候報了很多 gyp 錯誤&#xff0c;其中包括 npm error npm error ModuleNotFoundError: No module named distutils。 問題原因是我在使用 brew install node22 的過程中自動把 python 升級到了 3.13。而 distutils …

IPD流程落地:項目任務書Charter開發

目錄 簡介 第一個方面&#xff0c;回答的是Why的問題。 第二點&#xff0c;要回答做什么的問題&#xff0c;也就是產品定義What的問題。 第三點就是要回答執行策略與計劃的問題&#xff0c;也就是How、When、Who的問題。 第四點是對上述這些分析的總結分析&#xff0c;要為…

Qt popup窗口半透明背景

半透明彈窗需要paintEvent()接口支持 方法一&#xff1a;使用setStyleSheet設置半透明樣式&#xff0c;如果是子窗口&#xff0c;則可注釋構建函數內屬性設置 class TranslucentWidget : public QWidget { public: explicit TranslucentWidget(QWidget *parent nullptr)…

Excel快捷鍵大全

Excel快捷鍵 工作表操作快速選擇區域快速跳轉/視圖操作單元格公式批量填充與編輯功能鍵打開/關閉工作簿 工作表操作 快捷鍵功能ShiftF11(或Alt→H→I→S)默認插入新工作表到當前工作表左側的左側Alt→E→L→Enter刪除當前工作表&#xff0c;刪除后不可銷&#xff0c;須謹慎操作…

SQLMesh 用戶定義變量詳解:從全局到局部的全方位配置指南

SQLMesh 提供了靈活的多層級變量系統&#xff0c;支持從全局配置到模型局部作用域的變量定義。本文將詳細介紹 SQLMesh 的四類用戶定義變量&#xff08;global、gateway、blueprint 和 local&#xff09;以及宏函數的使用方法。 一、變量類型概述 SQLMesh 支持四種用戶定義變量…

爬蟲學習-Scrape Center spa6 超簡單 JS 逆向

關卡 spa6 電影數據網站&#xff0c;無反爬&#xff0c;數據通過 Ajax 加載&#xff0c;數據接口參數加密且有時間限制&#xff0c;適合動態頁面渲染爬取或 JavaScript 逆向分析。 首先抓包發現get請求的參數token有加密。 offset表示翻頁&#xff0c;limit表示每一頁有多少…

webtrees——在線協作家譜

webtrees——在線協作家譜 內容 執照編碼風格和標準介紹系統要求互聯網瀏覽器兼容性安裝升級建設與發展Gedcom&#xff08;家譜&#xff09;文件安全備份從備份還原 執照 webtrees&#xff1a;在線家譜版權所有 2022 webtrees 開發團隊 該程序是免費軟件&#xff1a;您可以根據…

day 37

模型的保存和加載 僅保存模型參數 - 原理&#xff1a;保存模型的權重參數&#xff0c;不保存模型結構代碼。加載時需提前定義與訓練時一致的模型類。 - 優點&#xff1a;文件體積小&#xff08;僅含參數&#xff09;&#xff0c;跨框架兼容性強&#xff08;需自行定義模型結…

MFC:獲取所有打印機的名稱(打印機模塊-2)

背景&#xff1a; “遍歷當前用戶的每一臺虛擬打印機&#xff0c;將其默認紙張設置為 A4 并設置為縱向。” 實現原理&#xff1a; 1.從當前用戶的注冊表讀取所有已配置的打印機&#xff1b; 2.遍歷每臺打印機&#xff1b; 3.輸出其邏輯與實際紙張大小&#xff1b; 4.嘗試設置…

Python驅動的游戲場景實時生成:如何用AI創造無限可能?

友友們好! 我是Echo_Wish,我的的新專欄《Python進階》以及《Python!實戰!》正式啟動啦!這是專為那些渴望提升Python技能的朋友們量身打造的專欄,無論你是已經有一定基礎的開發者,還是希望深入挖掘Python潛力的愛好者,這里都將是你不可錯過的寶藏。 在這個專欄中,你將會…

手機發熱怎么辦?

1?關閉后臺程序 &#x1f449; 把后臺運行的其他程序關掉&#xff0c;玩游戲或看視頻前&#xff0c;先清理一下后臺&#xff0c;避免發熱 2?“脫掉”手機殼 &#x1f449;夏天可以換成輕薄的散熱殼&#xff0c;比如金屬、亞克力材質的&#xff0c;或者暫時取下手機殼 3?物理…

【安全攻防與漏洞?】??HTTPS中的常見攻擊與防御??

HTTPS 中常見攻擊與防御策略涵蓋中間人攻擊&#xff08;MITM&#xff09;、SSL剝離、重放攻擊等&#xff0c;幫助構建安全的 HTTPS 通信環境&#xff1a; 一、中間人攻擊&#xff08;MITM&#xff09; 攻擊原理 場景&#xff1a;攻擊者通過偽造證書或劫持網絡流量&#xff0c…

如何搭建perfino監控(分析java服務性能)

本文主要解釋如何搭建perfino監控服務, 用于關注生產環境的性能指標, 提前知道什么時候達到服務器資源瓶頸, 避免資源不足時手忙腳亂~ 1. 安裝與部署? ??1. 下載與安裝? ?官網下載?&#xff1a;Perfino 官網 獲取最新版本&#xff08;支持 Windows/Linux/macOS&#xf…

5 分鐘速通密碼學!

讓我們開始第一部分&#xff1a;密碼學基礎 (Cryptography Basics)。 第一部分&#xff1a;密碼學基礎 (Cryptography Basics) 1. 什么是密碼學&#xff1f; 想象一下&#xff0c;在古代戰爭中&#xff0c;將軍需要向遠方的部隊傳遞作戰指令。如果直接派人送信&#xff0c;信…

MyBatis入門:快速搭建數據庫操作框架 + 增刪改查(CRUD)

一、創建Mybatis的項目 Mybatis 是?個持久層框架, 具體的數據存儲和數據操作還是在MySQL中操作的, 所以需要添加MySQL驅動 1.添加依賴 或者 手動添加依賴 <!--Mybatis 依賴包--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactI…

基于Ubuntu的ros版本切換

解決在同一個虛擬機中管理兩個不同版本的ros 基于Ubuntu&#xff08;20.04&#xff09; ros版本1和版本2的切換 前期準備&#xff1a;已經在Ubuntu中安裝了兩個版本的ros&#xff0c;這里以版本1的noetic和版本2的foxy為例 在bashrc中&#xff1a; # ~/.bashrc: executed by…