Leetcode刷題筆記 135 分發糖果

2021-10-12 05:09:10 字數 1205 閱讀 9344

題目

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

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

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

相鄰的孩子中,評分高的孩子必須獲得更多的糖果。

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

示例 1:

輸入: [1,0,2]

輸出: 5

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

示例 2:

輸入: [1,2,2]

輸出: 4

解釋: 你可以分別給這三個孩子分發 1、2、1 顆糖果。第三個孩子只得到 1 顆糖果,這已滿足上述兩個條件。

解法

看起來比較難 其實通過兩次遍歷就可以確定

每個人至少一顆糖 初始化陣列

先從左到右 如果右邊的比左邊的大 右邊的 = 左邊的糖數+1

再從右到左 如果左邊的比右邊的大 左邊的 = max(左邊的,右邊的+1)

最後全部加一起

**

#include

#include

#include

using

namespace std;

class

solution

for(

int i = n-

2; i >=

0;i--

)int sum =0;

for(

int i =

0;i < n;i++

) sum +

= ans[i]

;return sum;}}

;int

main()

; solution s;

cout

(rating)

}

今天也是愛zz的一天哦!

LeetCode刷題 135分發糖果

問題 老師想給孩子們分發糖果,有 n 個孩子站成了一條直線,老師會根據每個孩子的表現,預先給他們評分。你需要按照以下要求,幫助老師給這些孩子分發糖果 每個孩子至少分配到 1 個糖果。相鄰的孩子中,評分高的孩子必須獲得更多的糖果。那麼這樣下來,老師至少需要準備多少顆糖果呢?示例1 輸入 1,0,2 輸...

Leetcode刷題筆記

1.兩數之和給定乙個整數陣列nums 和乙個目標值target,請你在該陣列中找出和為目標值的那兩個整數,並返回他們的陣列下標。ps 你可以假設每種輸入只會對應乙個答案。但是,你不能重複利用這個陣列中同樣的元素。思路 用target減去nums中的每乙個數,並設立乙個字典來記錄對應的下標 class...

LeetCode刷題筆記

實現strstr 給定乙個 haystack 字串和乙個 needle 字串,在 haystack 字串中找出 needle 字串出現的第乙個位置 從0開始 如果不存在,則返回 1。示例 1 輸入 haystack hello needle ll 輸出 2 示例 2 輸入 haystack aaaa...