[프로그래머스] 치킨 쿠폰 파이썬

xianxbabx·2023년 3월 21일
0

알고리즘

목록 보기
12/14

문제 설명

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

제한사항

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

입출력 예

chickenresult
10011
1,081120

입출력 예 설명

입출력 예 #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합니다.

나의 코드

def solution(chicken):
    
    coupon = 0
    while True:
        service = chicken // 10
        chicken = chicken - (10*service) + service    
        coupon += service
        
        if chicken < 10:
            break
            
    return coupon

풀이 💫

딱 봐도 계속 반복되는게 반복문을 써야하는데, for문은 너무 복잡해질 것 같아서 while문으로 풀어보았다. while문이 익숙치 않아 헤맸지만, 먼저 해야할 것 부터 설명해보겠다.

  1. 치킨 1마리 당 쿠폰 1개
  2. 쿠폰 10개 --> 서비스 치킨 1마리 --> 쿠폰 1개

while문으로 service 변수에 chicken을 10으로 나눈 몫을 담아준다. 그 다음 chicken 변수에 서비스로 받은 치킨의 수를 다시 정의해주었다. coupon 변수는 service 변수를 합해나가고 만약, chicken 값이 10보다 작으면 while문을 탈출시켜 구해보았다. 🙇🏻‍♀️

0개의 댓글