코테공부
프로그래머스 16일차 - 치킨 쿠폰
알면 알 수록 재밌다!
2023. 3. 2. 12:22
프로그래머스 치킨은 치킨을 시켜먹으면 한 마리당 쿠폰을 한 장 발급합니다. 쿠폰을 열 장 모으면 치킨을 한 마리 서비스로 받을 수 있고, 서비스 치킨에도 쿠폰이 발급됩니다. 시켜먹은 치킨의 수 chicken이 매개변수로 주어질 때 받을 수 있는 최대 서비스 치킨의 수를 return하도록 solution 함수를 완성해주세요.
제한사항
chicken은 정수입니다.
0 ≤ chicken ≤ 1,000,000
입출력 예 #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합니다.
해설
쿠폰이 10개 이상이면 쿠폰으로 치킨을 시켜먹어서 1마리를 더 먹을 수 있기 때문에 while문으로 계속 반복시킨다.
쿠폰을 10으로 나눠서 나머지를 센다. math.floor(coupon / 10)에서 예를들어 13이면 /10 이면 1을 반환한다.
이 개수를 cnt라는 변수에 계속 더한다.
나머지 쿠폰의 수를 세야하므로 10마리당 1개씩 쿠폰이 생기므로 나머지 쿠폰 coupon % 10을 더하면 나머지 쿠폰 개수가 되므로 이걸 반복시킨다.
진짜 마지막 쿠폰이 9개 미만이면 치킨을 못시키니까 버린다.
이걸 반복하면 몫만 더하는데 모든 몫을 더한 cnt를 리턴한다.