135 分發糖果

2022-07-26 12:57:13 字數 1045 閱讀 2351

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

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

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

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

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

示例 1:

輸入: [1,0,2]

輸出: 5

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

示例 2:

輸入: [1,2,2]

輸出: 4

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

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

解法**於題解,

左規則:乙個孩子分數大於其左邊孩子分數,那麼他的糖果數量等於左邊孩子糖果數量+1

右規則:乙個孩子分數大於其右邊孩子分數,那麼他的糖果數量等於右邊孩子糖果數量+1

用乙個數列記錄滿足左規則數量的糖果,另乙個陣列記錄右規則糖果數量

左規則與右規則數量最大值即為能滿足兩條規則的糖果數量

class solution135 

int left = new int[ratings.length];

int right = new int[ratings.length];

arrays.fill(left, 1);

arrays.fill(right, 1);

for(int i = 1; i < ratings.length; i++)

}for(int i = ratings.length-2; i >= 0; i--)

}for(int i = 0; i < ratings.length; i++)

return res;

}}

135 分發糖果

題目.high 其實就是求每個數左邊或者右邊連續小於自己的個數。感覺不是很難啊。package main import fmt func candy ratings int int candies make int len ratings for i 0 i len ratings i lesscn...

135 分發糖果

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

135 分發糖果

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