Leetcode 第455题 分发饼干
题目链接:https://leetcode-cn.com/problems/assign-cookies/
题目描述:
思路分析:
此题很明显是使用贪心算法的思想去做的,饼干有分大小,孩子的胃口也分大小。为了使分配最优化,当然是在满足孩子的胃口的情况下,饼干的大小尽量小。因为大饼干既可以满足胃口小的,也可以满足胃口大的。所以此题的局部最优便是大饼干分给胃口大的孩子,全局最优便是喂饱尽量多的孩子。解题步骤是:先排序,再分配。
Java代码整体如下:
class Solution {
public int findContentChildren(int[] g, int[] s) {
//思路:大饼干喂大胃口
Arrays.sort(g);
Arrays.sort(s);
int i = s.length - 1;
int res = 0;
for(int j = g.length - 1; j >= 0; j--){
if(i >= 0 && s[i] >= g[j]){
res++;
i--; //这句一定要写在判断里面,如果写在外面则是饼干一次分配不了,便丢弃饼干了,导致结果错误。
}
}
return res;
}
}