민수는 다양한 지폐를 수집하는 취미를 가지고 있습니다. 지폐마다 크기가 달라 지갑에 넣으려면 여러 번 접어서 넣어야 합니다. 예를 들어 지갑의 크기가 30 15이고 지폐의 크기가 26 17이라면 한번 반으로 접어 13 * 17 크기로 만든 뒤 90도 돌려서 지갑에 넣을 수 있습니다. 지폐를 접을 때는 다음과 같은 규칙을 지킵니다.
지갑의 가로, 세로 크기를 담은 정수 리스트 wallet
과 지폐의 가로, 세로 크기를 담은 정수 리스트 bill
가 주어질 때, 지갑에 넣기 위해서 지폐를 최소 몇 번 접어야 하는지 return하도록 solution함수를 완성해 주세요.
지폐를 지갑에 넣기 위해 접어야 하는 최소 횟수를 구하는 과정은 다음과 같습니다.
1. 지폐를 접은 횟수를 저장할 정수 변수 answer를 만들고 0을 저장합니다.
2. 반복문을 이용해 bill의 작은 값이 wallet의 작은 값 보다 크거나 bill의 큰 값이 wallet의 큰 값 보다 큰 동안 아래 과정을 반복합니다.
2-1. bill[0]이 bill[1]보다 크다면
bill[0]을 2로 나누고 나머지는 버립니다.
2-2. 그렇지 않다면
bill[1]을 2로 나누고 나머지는 버립니다.
2-3. answer을 1 증가시킵니다.
3. answer을 return합니다.
셔틀 운행 횟수 n
, 셔틀 운행 간격 t
, 한 셔틀에 탈 수 있는 최대 크루 수 m
, 크루가 대기열에 도착하는 시각을 모은 배열 timetable
이 입력으로 주어진다.
wallet
의 길이 = bill
의 길이 = 2
10 ≤ wallet[0]
, wallet[1]
≤ 100
10 ≤ bill[0]
, bill[1]
≤ 2,000
wallet | bill | result |
---|---|---|
[30, 15] | [26, 17] | 1 |
[50, 50] | [100, 241] | 4 |
문제에 주어진 접어야 하는 최소 횟수를 구하는 과정대로
wallet
에 bill
이 들어가는지 체크한다.
isBillSmallerThanWallet1
,isBillSmallerThanWallet2
둘다 false일 경우
bill
에서 크기가 큰 수의 값을 2를 나눈값으로 줄여준다.
접은 횟수를 체크하기 위해 answer를 증가 시킨다.
class Solution {
public int solution(int[] wallet, int[] bill) {
int answer = 0;
while (true) {
boolean isBillSmallerThanWallet1 = wallet[0] >= bill[0] && wallet[1] >= bill[1];
boolean isBillSmallerThanWallet2 = wallet[0] >= bill[1] && wallet[1] >= bill[0];
// 지갑안에 들어가는지 체크
if (isBillSmallerThanWallet1 || isBillSmallerThanWallet2) {
break;
} else {
// bill의 긴 쪽을 접기
if (bill[0] > bill[1]) {
bill[0] /= 2;
} else {
bill[1] /= 2;
}
answer++;
}
}
return answer;
}
}