[Python] [BOJ] 리모컨(1107)

긍정왕·2021년 6월 22일
1

Algorithm

목록 보기
30/69

💡 문제 해결

  1. 정답을 +버튼만 눌러 이동하는 횟수로 설정
  2. 모든 상황을 고려하여 최대로 이동할 수 있는 범위로 설정
  3. 모든 채널의 경우에서 번호를 눌러 이동할 수 있는 채널인지 탐색
  4. 만약 번호를 눌러 이동할 수 있는 채널이라면 해당 채널에서 이동하려 하는 채널으로 이동하는데 눌러야 하는 버튼의 최소 횟수를 갱신

📌 아이디어와 최대 범위설정을 생각하는게 까다로웠던 문제



🧾 문제 설명

수빈이는 TV를 보고 있다. 
수빈이는 채널을 돌리려고 했지만, 버튼을 너무 세게 누르는 바람에, 일부 숫자 버튼이 고장났다.
리모컨에는 버튼이 0부터 9까지 숫자, +와 -가 있다. +를 누르면 
현재 보고있는 채널에서 +1된 채널로 이동하고, -를 누르면 -1된 채널로 이동한다. 
채널 0에서 -를 누른 경우에는 채널이 변하지 않고, 채널은 무한대 만큼 있다.

수빈이가 지금 이동하려고 하는 채널은 N이다. 
어떤 버튼이 고장났는지 주어졌을 때, 채널 N으로 이동하기 위해서 버튼을 최소 몇 번 눌러야하는지 구하는 프로그램을 작성하시오. 
수빈이가 지금 보고 있는 채널은 100번이다.

문제보기



🖨 입출력



📝 풀이

import sys

input = sys.stdin.readline

N = int(input())
M = int(input())
if M > 0:
    errors = list(map(int, input().split()))
else:
    errors = []

answer = abs(N - 100)
for channel in range(1000001):
    for num in str(channel):
        if int(num) in errors: break
    else:
        answer = min(answer, abs(channel - N) + len(str(channel)))

print(answer)

profile
Impossible + 땀 한방울 == I'm possible

0개의 댓글