피자 나눠 먹기(1)
https://school.programmers.co.kr/learn/courses/30/lessons/120814
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1) 문제
피자를 나눠먹을 사람의 수 n이 주어질 때, 모든 사람이 피자를 한 조각 이상 먹기 위해 필요한 피자의 수를 return 하는 solution 함수를 완성해보세요.
1 ≤ n ≤ 100
2) 예시
n | result |
---|---|
7 | 1 |
1 | 1 |
15 | 3 |
입출력 예 #1
7명이 최소 한 조각씩 먹기 위해서 최소 1판이 필요합니다.
입출력 예 #2
1명은 최소 한 조각을 먹기 위해 1판이 필요합니다.
입출력 예 #3
15명이 최소 한 조각씩 먹기 위해서 최소 3판이 필요합니다.
3) 풀이
1. 클래스 선언을 해줍니다
● class Solution {
클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.
2. 메소드 선언을 해줍니다.
● public int solution(int n) {
정수 n을 매개변수로 사용하는 solution 메소드를 선언해줍니다.
메소드의 결과값인 solution은 정수이 나오므로, 데이터 타입을 int로 해줍니다.
3. 정수 n에 대한 제한사항을 확인하고, 만족하지 않는다면 예외처리합니다.
● if (1 > n || n > 100) {
throw new IllegalArgumentException("n은 1 이상 100 이하 정수입니다.");
}
4. 모든 사람에게 1조각 이상씩 배분될 피자의 수를 변수 pizza로 선언하고 초기화합니다.
피자가게는 피자한판당 7조각으로 나누어주고, 사람의 수 n으로 나누었을 때 몫이 1 이상이 될 때까지
while문을 이용하여, 피자의 수를 1씩 증가시킵니다.
※ if문을 사용하지 않고, while문을 사용한 이유
while문의 경우, 괄호 내 조건이 참인 경우, 시행 이후 여전히 참이라면 계속하여 반복 시행합니다.
if문의 경우, 괄호 내 조건이 참인 경우 1회 시행 후 종료되기 때문입니다.
조건이 만족해야할때까지 피자수를 계속하여 1씩 늘려줘야했기때문에 while문을 사용했습니다.
● int pizza = 0;
while ((pizza * 7) / n < 1) {
pizza++;
}
return pizza;
}
}
4) 코드
class Solution {
public int solution(int n) {
if (1 > n || n > 100) {
throw new IllegalArgumentException("n은 1 이상 100 이하 정수입니다.");
}
int pizza = 0;
while ((pizza * 7) / n < 1) {
pizza++;
}
return pizza;
}
}
'Programmers Coding Test > Java' 카테고리의 다른 글
[프로그래머스 120830] Java - 코딩테스트 입문 / 양꼬치 (0) | 2024.01.31 |
---|---|
[프로그래머스 120816] Java - 코딩테스트 입문 / 피자 나눠 먹기 (3) (1) | 2024.01.31 |
[프로그래머스 120813] Java - 코딩테스트 입문 / 짝수는 싫어요 (1) | 2024.01.30 |
[프로그래머스 120812] Java - 코딩테스트 입문 / 최빈값 구하기 (0) | 2024.01.30 |
[프로그래머스 120808] Java - 코딩테스트 입문 / 분수의 덧셈 (0) | 2024.01.30 |