leetcode 分發餅乾

2021-09-27 07:03:53 字數 824 閱讀 8970

題目:

假設你是一位很棒的家長,想要給你的孩子們一些小餅乾。但是,每個孩子最多只能給一塊餅乾。對每個孩子 i ,都有乙個胃口值 gi ,這是能讓孩子們滿足胃口的餅乾的最小尺寸;並且每塊餅乾 j ,都有乙個尺寸 sj 。如果 sj >= gi ,我們可以將這個餅乾 j 分配給孩子 i ,這個孩子會得到滿足。你的目標是盡可能滿足越多數量的孩子,並輸出這個最大數值

注意:

你可以假設胃口值為正。

乙個小朋友最多只能擁有一塊餅乾

輸入: [1,2,3], [1,1]

輸出: 1

解釋: 

你有三個孩子和兩塊小餅乾,3個孩子的胃口值分別是:1,2,3。

雖然你有兩塊小餅乾,由於他們的尺寸都是1,你只能讓胃口值是1的孩子滿足。

所以你應該輸出1。

這一題典型的貪心演算法;解釋都在**的注釋裡;

時間複雜度為o(max(nlgn,mlgm))

class solution );

//以降序排列

sort(s.begin(),s.end(),(const int& lhs,const int &rhs));

//典型的貪心演算法,要使得全域性能夠有最多的小孩獲得餅乾,

//就要使得每一次的餅乾都能夠給最合適的小孩

//所以我每一次都把最大的餅乾給最大胃口的人

int j=0; //有多少人吃到

for(int i,j=0;i=g[i]) ++j;

else ++i;//說明當前的小孩胃口太大,滿足不了

}return j;

}};

Leetcode 分發餅乾

假設你是一位很棒的家長,想要給你的孩子們一些小餅乾。但是,每個孩子最多只能給一塊餅乾。對每個孩子 i 都有乙個胃口值 gi 這是能讓孩子們滿足胃口的餅乾的最小尺寸 並且每塊餅乾 j 都有乙個尺寸 sj 如果 sj gi 我們可以將這個餅乾 j 分配給孩子 i 這個孩子會得到滿足。你的目標是盡可能滿足...

LeetCode 分發餅乾 455

假設你是一位很棒的家長,想要給你的孩子們一些小餅乾。但是,每個孩子最多只能給一塊餅乾。對每個孩子 i 都有乙個胃口值 gi 這是能讓孩子們滿足胃口的餅乾的最小尺寸 並且每塊餅乾 j 都有乙個尺寸 sj 如果 sj gi 我們可以將這個餅乾 j 分配給孩子 i 這個孩子會得到滿足。你的目標是盡可能滿足...

LeetCode 分發餅乾(貪心策略)

假設你是一位很棒的家長,想要給你的孩子們一些小餅乾。但是,每個孩子最多只能給一塊餅乾。對每個孩子 i 都有乙個胃口值 gi 這是能讓孩子們滿足胃口的餅乾的最小尺寸 並且每塊餅乾 j 都有乙個尺寸 sj 如果 sj gi 我們可以將這個餅乾 j 分配給孩子 i 這個孩子會得到滿足。你的目標是盡可能滿足...