본문 바로가기
Algorithm/Programmers

[프로그래머스 JS] 치킨 쿠폰

by 그랴 2022. 12. 13.

코드 다 짜고 나니까 엄청 짧은 코드인데,,,, 이걸 왜 이렇게 오래 걸렸나 아직도 나 자신을 이해 못하는 중이다. 문제를 조금 헷갈렸나? 뭐 이런 날도 있는 거지 머리 잘 안돌아가는 그런....

 

반복문 돌릴 조건 맞추는 게 조금 헷갈렸다.. 

 

 

문제

더보기

문제 설명

프로그래머스 치킨은 치킨을 시켜먹으면 한 마리당 쿠폰을 한 장 발급합니다. 쿠폰을 열 장 모으면 치킨을 한 마리 서비스로 받을 수 있고, 서비스 치킨에도 쿠폰이 발급됩니다. 시켜먹은 치킨의 수 chicken이 매개변수로 주어질 때 받을 수 있는 최대 서비스 치킨의 수를 return하도록 solution 함수를 완성해주세요.


제한사항
  • chicken은 정수입니다.
  • 0 ≤ chicken ≤ 1,000,000

입출력 예chickenresult
100 11
1,081 120

입출력 예 설명

입출력 예 #1

  • 100마리를 주문하면 쿠폰이 100장 발급되므로 서비스 치킨 10마리를 주문할 수 있습니다.
  • 10마리를 주문하면 쿠폰이 10장 발급되므로 서비스 치킨 1마리를 주문할 수 있습니다.
  • 따라서 10 + 1 = 11 을 return합니다.

입출력 예 #2

  • 1081마리를 주문하면 쿠폰이 1081장 발급되므로 서비스 치킨 108마리를 주문할 수 있습니다. 그리고 쿠폰이 1장 남습니다.
  • 108마리를 주문하면 쿠폰이 108장 발급되므로 서비스 치킨 10마리를 주문할 수 있습니다. 그리고 쿠폰이 8장 남습니다.
  • 10마리를 주문하면 쿠폰이 10장 발급되므로 서비스 치킨 1마리를 주문할 수 있습니다.
  • 1마리를 주문하면 쿠폰이 1장 발급됩니다.
  • 가지고 있는 쿠폰이 총 10장이므로 서비스 치킨 1마리를 추가로 주문할 수 있습니다.
  • 따라서 108 + 10 + 1 + 1 = 120 을 return합니다.
function solution(chicken) {
    let answer = 0;
    let coupon = chicken;
    
    while(true){
        if (coupon >= 10){
            let left = Math.floor(coupon%10);
            let bonus = Math.floor(coupon/10);
            coupon = left + bonus;
            answer += bonus;
            console.log(left, bonus, coupon);
        } else {
            return answer;
        }
    }
}