DEV Community

Cover image for Optimizing Generosity: A Greedy Approach to LeetCode 455 (Assign Cookies)
Jerin
Jerin

Posted on

Optimizing Generosity: A Greedy Approach to LeetCode 455 (Assign Cookies)

Difficulty: Easy
Topics: Array, Two Pointers, Greedy, Sorting
Platform: Leetcode

Problem Statement

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 g[i], which is the minimum size of a cookie that the child will be content with; and each cookie j has a size s[j]. If s[j] >= g[i], 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.
Problem Statement Simplified
Give each children a cookies and each children have a dreed factor, give the result of how many children were satisfied.

Mistakes and Learning

  1. Dont check for eact value - in greedy problems we should look for threhold not exact value.
  2. At first used the 2 lists that stored the 2 arrays then remove the one by one from lists after going through the loop - The problem : If remove an element from index 2, then the element that was at index 3 will slides to index 2, will skip that element.

Example 1

Input: g = [1,2,3], s = [1,1]
Output: 1
Explanation: You have 3 children and 2 cookies. The greed factors of 3 children are 1, 2, 3. 
And even though you have 2 cookies, since their size is both 1, you could only make the child whose greed factor is 1 content.
You need to output 1.
Enter fullscreen mode Exit fullscreen mode

Example 2

Input: g = [1,2], s = [1,2,3]
Output: 2
Explanation: You have 2 children and 3 cookies. The greed factors of 2 children are 1, 2. 
You have 3 cookies and their sizes are big enough to gratify all of the children, 
You need to output 2.
Enter fullscreen mode Exit fullscreen mode

Key Insight

  • If s[i] ≥ g[i] then child satisfied.

  • If s[i]<g[i] then child not satisfied.

Algorithm

  1. Sort the 2 arrays.
  2. Initialize 2 integers for child and cookies.
  3. While the child is less than g.length and cookies is less than s.length.
  4. If s[cookies] is greater than or equal to g[child].
  5. Then child++.
  6. End if.
  7. Cookies++.
  8. End for loop.
  9. return child.

Algorithm in simple words

First, sort the 2 arrays so that we can we can match smallest available cookies with smallest greed factor.
Initialize 2 int pointers for child and cookies, then we will iterate and check if the current cookies can satify the current child if yes then we will move on to next child and next cookies, if not then we will move to next cookies . Return the child pointer with how many children are satisfied.

Java code

class Solution {
    public int findContentChildren(int[] g, int[] s) {
        Arrays.sort(g);
        Arrays.sort(s);
        int child=0;
        int cookies=0;
        while(child<g.length && cookies<s.length){
            if(s[cookies]>=g[child]){
                child++;
            }
            cookies++;
        }
        return child;
    }
}
Enter fullscreen mode Exit fullscreen mode

Time & Space Complexity

Time Complexity: O(n logn + m logm)
Space Complexity: O(logn + logm)

Top comments (0)