티스토리 뷰

코딩테스트 연습 - 치킨 쿠폰

문제 설명


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

제한사항


  • chicken은 정수입니다.
  • 0 ≤ chicken ≤ 1,000,000

입출력 예


chicken result

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합니다.

제출 코드


2022년 12월 31일

#include <string>
#include <vector>

using namespace std;

int solution(int chicken) {
    int answer = 0;
    int coupon = chicken;

    while (coupon >= 10)
    {
        int canEat = coupon / 10;
        answer += canEat;
        coupon = coupon % 10 + canEat;
    }

    return answer;
}

coupon = 그동안 먹은 치킨 마리수

canEat = 쿠폰으로 생성된 앞으로 먹을 수 있는 치킨 마리수

answer = 최대 서비스 치킨 마리수

<aside> 🍗 실제 치킨을 시켜먹으면서 쿠폰을 모은다고 가정하면 이해가 빠르다.

</aside>

  • 10마리를 먹었다면 쿠폰이 10장이 모여 1마리를 먹을 수 있게 된다.
  • 만일 100마리를 먹었다면, 이후에 10마리를, 그리고 또 1마리를, 도합 11마리의 서비스 닭을 먹을 수 있는 셈이다.

'😈 알고리즘 > 🖥️ 프로그래머스' 카테고리의 다른 글

🖥️ 등수 매기기 🙋  (0) 2023.02.15
🖥️ 유한소수 판별하기  (0) 2023.02.14
🖥️ 문자열 밀기  (0) 2023.02.12
🖥️ 직사각형 넓이 구하기  (0) 2023.02.11
🖥️ 로그인 성공?  (0) 2023.02.10
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
«   2025/06   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30
링크
Total
Today
Yesterday