[LeetCode#875] Koko Eating Bananas

2025. 1. 3. 00:30·Algorithm/문제풀이

 

❐ Description


문제 링크 Koko Eating Bananas
난이도 medium / Gold 4~3

 

 

 

 

 

❐ 문제 분석 및 접근


 

  • piles : 바나나 더미
  • h : 가드가 자리를 비우는 시간
  • k : 원숭이가 한 시간동안 먹을 수 있는 바나나 갯수

 

int[] piles = {10, 13, 34, 55}

예를 들어 위와 같은 경우에, 원숭이가 시간당 먹을 수 있는 바나나의 갯수(k)가 15라면 

원숭이가 모든 바나나 더미를 다 먹는데 걸리는 시간은 아래와 같을 것이다.

‣ 10개 - 1시간
‣ 13개 - 1시간
‣ 34개 - 3시간
‣ 55개 - 4시간

 

 

원숭이가 먹을 수 있는 최소 바나나 갯수는 1개이고 최대 바나나 갯수는 piles 중 가장 큰 수이다.

⇨ 정답 k는 이 사이에 존재한다.

 

그리고 위의 예시에서 `k = 15` 일 때 34개의 바나나를 먹는데 3시간이 걸린다.

⇨ `15개 / 15개 / 나머지 4개`

 

이 부분을 계산하기 위해서는 올림을 구현해줘야 한다.

⇨ (pile + k - 1) / k

 

 

 

 

 

❐ Solution


public class Solution {
    public int minEatingSpeed(int[] piles, int h) {
        int left = 1;
        int right = (int) le9;
        
        while (left < right) {
            int mid = left + (right - left) / 2;
            
            int takenHour = 0;
           	for (int pile : piles) {
                // 올림 연산
                takenHour += (pile + mid - 1) / mid;
            }
            
            if (takenHour <= h) {
                // 현재 mid도 다음 범위에 포함되어야 한다.
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        return left;
    }
}

 

 

 

 

 


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

[LeetCode#198] House Robber  (0) 2025.01.09
[LeetCode#128] Longest Consecutive Sequence  (0) 2025.01.07
[LeetCode#1631] Path With Minimum Effort  (0) 2024.12.23
[LeetCode#2517] Maximum Tastiness of Candy Basket  (0) 2024.12.20
[LeetCode#130] Surrounded Regions  (0) 2024.12.14
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#198] House Robber
  • [LeetCode#128] Longest Consecutive Sequence
  • [LeetCode#1631] Path With Minimum Effort
  • [LeetCode#2517] Maximum Tastiness of Candy Basket
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (207)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (6)
        • Java (3)
        • Kotlin (3)
      • 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 (39)
        • 친절한 SQL 튜닝 (9)
        • 데이터 중심 애플리케이션 설계 (14)
        • 이벤트 기반 마이크로서비스 구축 (6)
        • Spring Batch docs (10)
        • Quartz docs (0)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[LeetCode#875] Koko Eating Bananas
상단으로

티스토리툴바