[LeetCode#455] Assign Cookies

2024. 9. 19. 18:01·Algorithm/문제풀이

❒ Description


레벨 Easy
날짜 2024.09.19 (목)
제목 Assign Cookies
링크 https://leetcode.com/problems/assign-cookies/description/
자료구조 배열
알고리즘 그리디
시간 복잡도 O(NlogN)

 

 

 

 

 

❒ 문제 분석


우선 각 배열의 의미를 잘 이해해야 한다.

  • g 배열 : i번 째 아이들를 만족시킬 수 있는 쿠키의 크기들의 집합
  • i 배열 : 각 쿠키의 크기를 나타낸 집합

예를 들어 g = {1, 2, 3}, s = {1, 1} 이라면 최대 1명의 아이만 만족할 수 있다.

  • s[1]은 g[1]을 만족시킬 수 있다.
  • s[2]은 g[2]을 만족시킬 수 없다.
  • s[2]은 g[3]을 만족시킬 수 없다.

 

 

 

 

 

❒ Solution


public int findContentChildren(int[] g, int[] s) {
    // 효율적으로 그리디 알고리즘을 해결하기 위해서 각 배열 정렬
    Arrays.sort(g);
    Arrays.sort(s);
    
    int gMarker = 0;
    int sMarker = 0;
    
    while (gMarker < g.length && sMarker < s.length) {
        if (g[gMarker] <= s[sMarker]) {
            gMarker ++;
        }
        sMarker ++;
    }
    return gMarker;
}

우선 배열 g와s를 정렬해줘야 한다. 그러면 왜 정렬해줘야 할까? 이 문제에서 배열을 정렬하는 이유는 쿠키의 크기를

아이들의 요구 만족도에 맞춰 효율적으로 할당하기 위함이다. 즉, 작은 쿠키부터 순차적으로 작은 만족도를 가진

아이에게 할당하는 방식으로, 더 많은 아이를 만족시킬 수 있는 선택을 하기 위함입니다.

'Algorithm > 문제풀이' 카테고리의 다른 글

[LeetCode#] Invert Binary Tree  (0) 2024.09.22
[LeetCode#687] Longest Univalue Path  (0) 2024.09.21
[LeetCode#134] Gas Station  (0) 2024.09.18
[LeetCode#621] Task Scheduler  (0) 2024.09.17
[LeetCode#406] Queue reconstruction by height  (0) 2024.09.17
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#] Invert Binary Tree
  • [LeetCode#687] Longest Univalue Path
  • [LeetCode#134] Gas Station
  • [LeetCode#621] Task Scheduler
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (175)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (4)
        • Java (3)
        • Kotlin (1)
      • Back-End (13)
        • SpringBoot (1)
        • Trouble Shooting (0)
        • Setup & Configuration (1)
        • SQL (3)
        • Redis (8)
      • Architecture (6)
        • Multi Module (1)
        • DDD (5)
      • CS (30)
        • Data Structure (6)
        • Operating System (0)
        • Network (12)
        • Database (10)
        • Design Pattern (2)
      • Algorithm (78)
        • 내용 정리 (18)
        • 문제풀이 (60)
      • DevOps (6)
        • AWS (5)
        • Git (1)
      • Front-End (1)
        • Trouble Shooting (1)
      • Project (6)
        • 페이스콕 (6)
      • Book (9)
        • 이벤트 기반 마이크로서비스 구축 (7)
        • 친절한 SQL 튜닝 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Two-Pointer
    오블완
    Back-Tracking
    greedy
    binarysearch
    부분단조성
    sliding-window
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[LeetCode#455] Assign Cookies
상단으로

티스토리툴바