Assume you are an awesome parent and want to give your children some cookies. But, you should give each child at most one cookie. Each child i has a greed factor gi, which is the minimum size of a cookie that the child will be content with; and each cookie j has a size sj. If sj>= gi, we can assign the cookie j to the child i, and the child i will be content. Your goal is to maximize the number of your content children and output the maximum number.

Note:
You may assume the greed factor is always positive.
You cannot assign more than one cookie to one child.

这个题是贪心算法,为了尽可能多地满足孩子,必须使用尽可能小的且大于greed factor的size的饼干

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        if(s == null || s.length == 0)
            return 0;


        Arrays.sort(g);
        Arrays.sort(s);

        int i = 0;
        int j = 0;
        int count = 0;

        while(j < s.length && i < g.length) {
            if(s[j] >= g[i]) {
                count++;
                i++;
                j++;
            } else {
                j++;
            }
        }

        return count;
    }
}

results matching ""

    No results matching ""