[프로그래머스 / PCCP 기출문제 9번 / Python] 지폐 접기

2025. 5. 31. 20:28·Algorithm/프로그래머스
반응형

문제 출처

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합니다.
  • 위의 의사코드와 작동방식이 다른 코드를 작성해도 상관없습니다.

내 답안

def solution(wallet, bill):
    answer = 0
    while max(wallet) < max(bill) or min(wallet) < min(bill):
        bill = [max(bill) // 2, min(bill)]
        answer += 1
    return answer

결론 및 느낀점

이 문제를 통해서 지폐를 접어서 지갑에 맞게 만드는 간단한 문제였지만, 조건에 따라 알고리즘을 어떻게 구현해야 할지 고민해볼 수 있는 좋은 기회였습니다. 지폐의 가로, 세로 길이 중 긴 쪽을 접는 과정을 반복하면서 접어야 하는 최소 횟수를 구하는 과정이 직관적이면서도 효율적인 접근을 요구했습니다.

특히, 두 매개변수(지갑 크기와 지폐 크기) 간의 크기 비교를 통해 언제 접기를 멈출지 결정하는 로직을 짜는 것이 핵심이었습니다. 이런 유형의 문제는 실제 코딩 테스트에서도 자주 등장하는 유형이기 때문에, 이번 경험을 통해 유사한 문제에 더 빠르고 정확하게 접근할 수 있는 능력을 기를 수 있었다고 생각합니다.

반응형
저작자표시 비영리 변경금지 (새창열림)

'Algorithm > 프로그래머스' 카테고리의 다른 글

[프로그래머스 / PCCP 기출문제 3번 / Python] 충돌위험 찾기  (0) 2025.05.31
[프로그래머스 / PCCP 기출문제 2번 / Python] 퍼즐 게임 챌린지  (0) 2025.05.31
[프로그래머스 / PCCP 기출문제 1번 / Python] 동영상 재생기  (0) 2025.05.31
[KAKAO BLIND RECRUITMENT / 2021 / Python] 합승 택시 요금  (0) 2025.05.30
[KAKAO BLIND RECRUITMENT / 2023 / Python] 이모티콘 할인행사  (0) 2025.05.30
'Algorithm/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 / PCCP 기출문제 3번 / Python] 충돌위험 찾기
  • [프로그래머스 / PCCP 기출문제 2번 / Python] 퍼즐 게임 챌린지
  • [프로그래머스 / PCCP 기출문제 1번 / Python] 동영상 재생기
  • [KAKAO BLIND RECRUITMENT / 2021 / Python] 합승 택시 요금
Kun Woo Kim
Kun Woo Kim
안녕하세요, 김건우입니다! 웹과 앱 개발에 열정적인 전문가로, React, TypeScript, Next.js, Node.js, Express, Flutter 등을 활용한 프로젝트를 다룹니다. 제 블로그에서는 개발 여정, 기술 분석, 실용적 코딩 팁을 공유합니다. 창의적인 솔루션을 실제로 적용하는 과정의 통찰도 나눌 예정이니, 궁금한 점이나 상담은 언제든 환영합니다.
  • Kun Woo Kim
    WhiteMouseDev
    김건우
  • 깃허브
    포트폴리오
    velog
  • 전체
    오늘
    어제
  • 공지사항

    • [인사말] 이제 티스토리에서도 만나요! WhiteMouse⋯
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
    • 분류 전체보기 (100) N
      • Frontend Development (39) N
      • Backend Development (21) N
      • Algorithm (33) N
        • 백준 (11) N
        • 프로그래머스 (17)
        • 알고리즘 (5)
      • Infra (1)
      • 자료구조 (3)
  • 링크

    • Github
    • Portfolio
    • Velog
  • 인기 글

  • 태그

    frontend development
    tailwindcss
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Kun Woo Kim
[프로그래머스 / PCCP 기출문제 9번 / Python] 지폐 접기
상단으로

티스토리툴바