https://school.programmers.co.kr/learn/courses/30/lessons/120884
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
■ 문제 설명
프로그래머스 치킨은 치킨을 시켜먹으면 한 마리당 쿠폰을 한 장 발급합니다. 쿠폰을 열 장 모으면 치킨을 한 마리 서비스로 받을 수 있고, 서비스 치킨에도 쿠폰이 발급됩니다. 시켜먹은 치킨의 수 chicken이 매개변수로 주어질 때 받을 수 있는 최대 서비스 치킨의 수를 return하도록 solution 함수를 완성해주세요.
■ 제한사항
- chicken은 정수입니다.
- 0 ≤ chicken ≤ 1,000,000
■ 입출력 예
chicken | result |
100 | 11 |
1,081 | 120 |
■ 나의 코드
class Solution {
public int solution(int chicken) {
int answer = 0;
while(chicken >= 10) {
int service = chicken / 10;
int coupon = chicken % 10;
chicken = service + coupon;
answer += service;
}
return answer;
}
}
■ 코드 풀이
while문을 사용해 쿠폰이 10개 이상 남았을 때만 반복되게 설정한 후 service에 쿠폰으로 바꿀 수 있는 개수를 계산하고, coupon에는 쿠폰으로 바꾼 뒤의 나머지의 개수를 계산할 수 있도록 했다. 그 후, chicken에 쿠폰 개수와 그 나머지를 더했고, answer에 쿠폰으로 바꿀 수 있는 개수를 누적해 값을 return했다.
'프로그래머스 > Java' 카테고리의 다른 글
숫자 찾기 (0) | 2023.02.24 |
---|---|
배열 자르기 (0) | 2023.02.24 |
문자열 정렬하기 (2) (0) | 2023.02.24 |
직각삼각형 출력하기 (0) | 2023.02.23 |
7의 개수 (0) | 2023.02.23 |