JAVA學習-練習試用Java實現“分發糖果”

問題:

老師想給孩子們分發糖果,有 N 個孩子站成了一條直線,老師會根據每個孩子的表現,預先給他們評分。

需要按照以下要求,幫助老師給這些孩子分發糖果:

每個孩子至少分配到 1 個糖果。

評分更高的孩子必須比他兩側的鄰位孩子獲得更多的糖果。

那么這樣下來,老師至少需要準備多少顆糖果呢?

示例 1:

輸入:[1,0,2]

輸出:5

解釋:你可以分別給這三個孩子分發 2、1、2 顆糖果。

示例 2:

輸入:[1,2,2]

輸出:4

解釋:你可以分別給這三個孩子分發 1、2、1 顆糖果。

第三個孩子只得到 1 顆糖果,這已滿足上述兩個條件。

解答思路:

以下是使用 Java 語言解決此問題的代碼:

import java.util.ArrayList;import java.util.List;public class CandyDistribution {public static void main(String[] args) {int[] ratings = {1, 0, 2};System.out.println(distributeCandies(ratings));}public static int distributeCandies(int[] ratings) {List<Integer> candies = new ArrayList<>();for (int i = 0; i < ratings.length; i++) {candies.add(1);}for (int i = 1; i < ratings.length; i++) {if (ratings[i] > ratings[i - 1]) {candies.set(i, candies.get(i - 1) + 1);} else if (ratings[i] < ratings[i - 1]) {int j = i;while (j > 0 && ratings[j] < ratings[j - 1] && candies.get(j) >= candies.get(j - 1)) {candies.set(j - 1, candies.get(j) + 1);j--;}}}int sum = 0;for (Integer candy : candies) {sum += candy;}return sum;}}

這段代碼首先初始化一個包含每個孩子 1 顆糖果的列表。然后,它遍歷評分數組。如果當前孩子的評分高于前一個孩子的評分,它會將當前孩子的糖果數增加 1。如果當前孩子的評分低于前一個孩子的評分,它會從后往前找到第一個評分高于當前孩子的孩子,并將該孩子的糖果數增加 1。最后,它計算并返回糖果總數。

這段代碼的時間復雜度為 O(n),其中 n 是孩子的數量,因為它只需要遍歷評分數組一次。空間復雜度也為 O(n),因為它需要創建一個新的列表來存儲每個孩子的糖果數。

(文章為作者在學習java過程中的一些個人體會總結和借鑒,如有不當、錯誤的地方,請各位大佬批評指正,定當努力改正,如有侵權請聯系作者刪帖。)

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

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

相關文章

FastAPI:高性能異步API框架

文章目錄 引言官網鏈接FastAPI 原理1. 基于 Starlette 和 Pydantic2. 路由與依賴注入3. 自動文檔 使用方法安裝 FastAPI創建一個簡單的API運行服務器 優缺點優點缺點 結論 引言 在快速發展的Web和移動應用時代&#xff0c;構建高效、可擴展的API成為了現代軟件開發的關鍵需求之…

Thingsboard 系列之通過 ESP8266+MQTT 模擬設備上報數據到平臺

前置工作 Thingsboard平臺ESP 8266 NodeMCU 開發板IDE&#xff1a; Arduino 或 VScode 均可 服務端具體對接流程 系統管理員賬號通過 Thingsboard 控制面板創建租戶等信息并以租戶賬號登錄 實體 —> 設備維護具體設備信息 創建完成后通過管理憑據修改或直接復制訪問令牌…

python 冷知識 66 個 0708

66個有趣的Python冷知識 內聯注釋 可以在代碼行尾使用 # 進行內聯注釋&#xff0c;例如 x 10 # 這是一個內聯注釋。 多行注釋 多行注釋可以用三個引號 或 """ 包裹。 分數 fractions 模塊提供了分數類型&#xff0c;可以精確表示分數值。 小數 decimal 模塊…

致遠OA同步組織架構到企業微信

致遠OA同步組織架構到企業微信 可適配任何系統 背景 原有的微協同無法滿足人員同步&#xff0c;因為在啟用微協同的時候&#xff0c;企業微信已經存在人員&#xff0c;所以配置微協同之后&#xff0c;人員會出現新增而不會同步修改 方案 重寫同步&#xff0c;針對已經存在…

Visual Studio下安裝引入Boost庫

背景&#xff1a; 在 Win 上通過 Visual Studio 運行 c 代碼&#xff0c;引入頭文件 #include <boost/...>&#xff0c;顯式無法打開&#xff0c;需要手動下載boost并進行配置。 1、下載boost&#xff1a; Boost官網&#xff1a;Boost Downloads 下載boost&#xff0c…

網安加·百家講壇 | 關昕健:新時代企業數據安全運營思路

作者簡介&#xff1a;關昕健&#xff0c;某運營商安全專家&#xff0c;2015年獲CISSP認證&#xff0c;長期負責企業安全運營工作&#xff0c;關注國內外數據安全動態與解決方案&#xff0c;持續開展數據安全運營實踐。 近年來&#xff0c;隨著《數據安全法》的出臺和國家數據局…

Pytorch中的DataLoader類

&#x1f4da;博客主頁&#xff1a;knighthood2001 ?公眾號&#xff1a;認知up吧 &#xff08;目前正在帶領大家一起提升認知&#xff0c;感興趣可以來圍觀一下&#xff09; &#x1f383;知識星球&#xff1a;【認知up吧|成長|副業】介紹 ??如遇文章付費&#xff0c;可先看…

js逆向案例 | 加速樂反爬逆向

前言 加速樂作為一種常見的反爬蟲技術&#xff0c;在網絡上已有大量詳盡深入的教程可供參考。然而&#xff0c;對于那些初次接觸的人來說&#xff0c;直接面對它可能仍會感到困惑。 聲明 本文僅用于學習交流&#xff0c;學習探討逆向知識&#xff0c;歡迎私信共享學習心得。如…

oracle19 數據庫介紹

1.1Oracle數據庫概念和應用 每個人家里都會有冰箱&#xff0c;冰箱是用來干什么的&#xff1f;冰箱是用來存放食物的地方。同樣的&#xff0c;數據庫是存放數據的地方。正是因為有了數據庫后&#xff0c;可以直接查找數據。例如你每天使用余額寶查看自己的賬戶收益&#xff0c;…

【YOLOv5/v7改進系列】改進池化層為RFB

一、導言 論文 "Receptive Field Block Net for Accurate and Fast Object Detection" 中提出的 RFB (Receptive Field Block) 模塊旨在模仿人類視覺系統中的感受野結構&#xff0c;以增強深度學習模型對不同尺度和位置的目標檢測能力。下面總結了RFB模塊的主要優點…

MySQL數據庫巡檢步驟

MySQL巡檢 系統基本信息 機型號 IP CPU 內存 磁盤 (業務)系統信息 操作系統 主機名 操作系統巡檢 檢查內容 說明 檢查方法 結果&#xff08;異常需詳細說明&#xff09; 正常輸出結果 系統配置檢查 操作系 統版本 #uname –a □正常 □異常 顯示系統版本和核心補丁信…

AIGC時代程序員的躍遷——編程高手的密碼武器

&#x1f49d;&#x1f49d;&#x1f49d;歡迎來到我的博客&#xff0c;很高興能夠在這里和您見面&#xff01;希望您在這里可以感受到一份輕松愉快的氛圍&#xff0c;不僅可以獲得有趣的內容和知識&#xff0c;也可以暢所欲言、分享您的想法和見解。 推薦:kwan 的首頁,持續學…

一、redis-萬字長文讀懂redis

高性能分布式緩存Redis `第一篇章`1.1緩存發展史&緩存分類1.1.1 大型網站中緩存的使用帶來的問題1.1.2 常見緩存的分類及對比與memcache對比1.2 數據類型選擇&應用場景1.2.1 string1.2.2 hash1.2.3 鏈表1.2.4 set1.2.5 sortedset有序集合類型1.2.6 總結1.3 Redis高級應…

[數倉]三、離線數倉(Hive數倉系統)

第1章 數倉分層 1.1 為什么要分層 DIM&#xff1a;dimensionality 維度 1.2 數據集市與數據倉庫概念 1.3 數倉命名規范 1.3.1 表命名 ODS層命名為ods_表名DIM層命名為dim_表名DWD層命名為dwd_表名DWS層命名為dws_表名 DWT層命名為dwt_表名ADS層命名為ads_表名臨時表命名為…

昇思25天訓練營Day11 - 基于 MindSpore 實現 BERT 對話情緒識別

模型簡介 BERT全稱是來自變換器的雙向編碼器表征量&#xff08;Bidirectional Encoder Representations from Transformers&#xff09;&#xff0c;它是Google于2018年末開發并發布的一種新型語言模型。與BERT模型相似的預訓練語言模型例如問答、命名實體識別、自然語言推理、…

56、最近鄰向量量化(LVQ) 網絡訓練對輸入向量進行分類

1、LVQ 網絡訓練對輸入向量進行分類簡介 1&#xff09;簡介 LVQ&#xff08;最近鄰向量量化&#xff09;是一種簡單而有效的神經網絡模型&#xff0c;用于對輸入向量進行分類。LVQ網絡通過學習一組原型向量&#xff08;也稱為代碼矢量或參考向量&#xff09;&#xff0c;來表…

HTML5 WebSocket技術使用詳解

HTML5 WebSocket API 提供了一種在單個連接上進行全雙工通信的方式。這意味著客戶端和服務器可以同時發送和接收數據&#xff0c;而不需要像傳統的 HTTP 請求那樣進行多次請求和響應的輪詢。WebSocket 允許更實時的交互&#xff0c;非常適合需要快速、連續數據交換的應用場景&a…

SAP Build4-office 操作

1. 郵件操作 1.1 前期準備 商店中找到outlook的sdk&#xff0c;添加到build中 在process中添加outlook的SDK 電腦上裝了outlook的郵箱并且已經登錄 我用個人foxmail郵箱向outlook發了一封帶附件的銷售訂單郵件&#xff0c;就以此作為例子 1.2 搜索郵件 搜索有兩層&…

計算機視覺、目標檢測、視頻分析的過去和未來:目標檢測從入門到精通 ------ YOLOv8 到 多模態大模型處理視覺基礎任務

文章大綱 計算機視覺項目的關鍵步驟計算機視覺項目核心內容概述步驟1: 確定項目目標步驟2:數據收集和數據標注步驟3:數據增強和拆分數據集步驟4:模型訓練步驟5:模型評估和模型微調步驟6:模型測試步驟7:模型部署常見問題目標檢測入門什么是目標檢測目標檢測算法的分類一階…

CSS實現圖片裁剪居中(只截取剪裁圖片中間部分,圖片不變形)

1.第一種方式&#xff1a;&#xff08;直接給圖片設置&#xff1a;object-fit:cover;&#xff09; .imgbox{width: 100%;height:200px;overflow: hidden;position: relative;img{width: 100%;height: 100%; //圖片要設置高度display: block;position: absolute;left: 0;right…