[프로그래머스 Lv1.] 340199번 [PCCE 기출문제] 9번 / 지폐 접기 (JAVA)

2024. 11. 28. 17:29·Coding Test/프로그래머스[JAVA]

문제 설명

민수는 다양한 지폐를 수집하는 취미를 가지고 있습니다. 지폐마다 크기가 달라 지갑에 넣으려면 여러 번 접어서 넣어야 합니다. 예를 들어 지갑의 크기가 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

풀이

class Solution {
    public int solution(int[] wallet, int[] bill) {
        int answer = 0;

        while(Math.min(bill[0], bill[1]) > Math.min(wallet[0], wallet[1]) || Math.max(bill[0], bill[1]) > Math.max(wallet[0], wallet[1])) {
            if(bill[0] > bill[1]) bill[0] /= 2;
            else bill[1] /= 2;
            answer++;
        }
        
        return answer;
    }
}
저작자표시 비영리 변경금지 (새창열림)

'Coding Test > 프로그래머스[JAVA]' 카테고리의 다른 글

[프로그래머스 Lv1.] 140108번 문자열 나누기(JAVA)  (0) 2024.12.04
[프로그래머스 Lv1.] 42889번 실패율 (JAVA)  (0) 2024.11.28
[프로그래머스 Lv1.] 133499번 옹알이 (2) (JAVA)  (0) 2024.11.27
[프로그래머스 Lv1.] 161989번 덧칠하기 (JAVA)  (0) 2024.11.27
[프로그래머스 Lv1.] 12977번 소수 만들기 (JAVA)  (0) 2024.11.27
'Coding Test/프로그래머스[JAVA]' 카테고리의 다른 글
  • [프로그래머스 Lv1.] 140108번 문자열 나누기(JAVA)
  • [프로그래머스 Lv1.] 42889번 실패율 (JAVA)
  • [프로그래머스 Lv1.] 133499번 옹알이 (2) (JAVA)
  • [프로그래머스 Lv1.] 161989번 덧칠하기 (JAVA)
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (829)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (445)
        • 백준[JAVA] (108)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    데이터
    programmers
    리눅스
    CS지식
    자바
    python
    springboot
    Spring Security
    프로그래머스
    DB
    데이터베이스
    Java
    baekjoon
    JPA
    Oracle
    Flutter
    pcce 기출문제
    스프링부트
    플러터
    스프링 부트 쇼핑몰 프로젝트 with JPA
    시큐리티
    Linux
    리눅스마스터 1급
    리눅스마스터
    backjoon
    스프링
    spring
    백준
    CS
    postgresql
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[프로그래머스 Lv1.] 340199번 [PCCE 기출문제] 9번 / 지폐 접기 (JAVA)
상단으로

티스토리툴바