일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
- sec태그
- 입출력
- CPU
- 로그인정보 가져오기
- hackerrank
- 리눅스
- 오블완
- 멀티태스킹
- 프로그래머스
- java
- mvc 구성요소
- 티스토리챌린지
- 멀티프로세싱
- 오버로딩
- 객체지향
- over()
- SQL Mapper
- 캡슐화
- charset 변경
- spring security 로그인정보 가져오기
- 자바의 정석
- 쿠키
- mvc 동작
- spring security
- 혼공얄코
- spring security 설정
- 다형성
- 오버라이딩
- 자바의정석
- @modelattibute
- Today
- Total
쉽게 쉽게
[프로그래머스] 지폐 접기 -Java 본문
▤ 목차
1. 문제설명
https://school.programmers.co.kr/learn/courses/30/lessons/340199
문제 설명
민수는 다양한 지폐를 수집하는 취미를 가지고 있습니다. 지폐마다 크기가 달라 지갑에 넣으려면 여러 번 접어서 넣어야 합니다. 예를 들어 지갑의 크기가 30 * 15이고 지폐의 크기가 26 * 17이라면 한번 반으로 접어 13 * 17 크기로 만든 뒤 90도 돌려서 지갑에 넣을 수 있습니다. 지폐를 접을 때는 다음과 같은 규칙을 지킵니다.
지폐를 접을 때는 항상 길이가 긴 쪽을 반으로 접습니다.
접기 전 길이가 홀수였다면 접은 후 소수점 이하는 버립니다.
접힌 지폐를 그대로 또는 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합니다.
위의 의사코드와 작동방식이 다른 코드를 작성해도 상관없습니다.
제한사항
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 |
입출력 예 설명
입출력 예 #1
지문과 동일합니다.
입출력 예 #2
지폐를 접으면 다음과 같이 크기가 줄어듭니다. 따라서 4번 접으면 지갑에 넣을 수 있습니다.
[100, 241] -> [100, 120] -> [100, 60] -> [50, 60] -> [50, 30]
cpp를 응시하는 경우 리스트는 배열과 동일한 의미이니 풀이에 참고해주세요.
ex) 번호가 담긴 정수 리스트 numbers가 주어집니다. => 번호가 담긴 정수 배열 numbers가 주어집니다.
java를 응시하는 경우 리스트는 배열, 함수는 메소드와 동일한 의미이니 풀이에 참고해주세요.
ex) solution 함수가 올바르게 작동하도록 한 줄을 수정해 주세요. => solution 메소드가 올바르게 작동하도록 한 줄을 수정해 주세요.
2. 문제풀이
나의 풀이
class Solution {
public int solution(int[] wallet, int[] bill) {
int answer = 0;
while(true){
int wallet_min = Math.min(wallet[0], wallet[1]);
int wallet_max = Math.max(wallet[0], wallet[1]);
int bill_min = Math.min(bill[0], bill[1]);
int bill_max = Math.max(bill[0], bill[1]);
if(bill_min>wallet_min || bill_max>wallet_max){
if(bill[0] > bill[1]){
bill[0] = bill[0]/2;
}else{
bill[1] = bill[1]/2;
}
answer++;
}else{
break;
}
}
return answer;
}
}
조건만 잘 설정해주면 쉽게 풀리는 문제였다.
잘못된 내용이 있다면 지적부탁드립니다. 방문해주셔서 감사합니다. |
'문제풀이 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 데이터 분석 -Java (0) | 2024.11.22 |
---|---|
[프로그래머스] 이웃한 칸 -Java (2) | 2024.11.20 |
[프로그래머스] 신고 결과 받기 -Java (1) | 2024.11.14 |
[프로그래머스] 공원 산책 -Java (1) | 2024.11.12 |
[프로그래머스] 달리기 경주 -Java (0) | 2024.11.08 |