728x90
문제 설명
프로그래머스 치킨은 치킨을 시켜먹으면 한 마리당 쿠폰을 한 장 발급합니다. 쿠폰을 열 장 모으면 치킨을 한 마리 서비스로 받을 수 있고, 서비스 치킨에도 쿠폰이 발급됩니다. 시켜먹은 치킨의 수 chicken이 매개변수로 주어질 때 받을 수 있는 최대 서비스 치킨의 수를 return하도록 solution 함수를 완성해주세요.
제한사항
- chicken은 정수입니다.
- 0 ≤ chicken ≤ 1,000,000
입출력 예
처음 내 풀이
class Solution {
public int solution(int chicken) {
int serviceChicken = 0;
int coupon = chicken;
while (coupon >= 10) {
serviceChicken += coupon / 10;
coupon = serviceChicken + (coupon % 10);
}
return serviceChicken;
}
}
쿠폰에 서비스 치킨을 그냥 더해버렸다.. ㅠㅜ 말도 안되는 로직이다.
고민 끝에 맞춘 풀이
class Solution {
public int solution(int chicken) {
int service = 0;
while (chicken >= 10) {
service += chicken / 10;
chicken = (chicken / 10) + (chicken % 10);
}
return service;
}
}
'Back-end > Algorithm' 카테고리의 다른 글
[프로그래머스 입문] 피자 나눠 먹기 (3) (2) | 2023.06.28 |
---|---|
[프로그래머스] 레벨1 콜라츠 추측 (0) | 2023.06.27 |
[프로그래머스] 레벨2 최댓값과 최솟값 (0) | 2023.06.25 |
[프로그래머스] 직사각형 별찍기 (0) | 2023.06.24 |
프로그래머스 (Level 1) 완주하지 못한 선수 [Java] (0) | 2023.06.23 |