알고리즘(백준, 프로그래머스)/[Code-Up] 그리디

[Code-Up] 그리디 / 파이썬 / 3120: 리모컨

마법사 코딩공주 2023. 5. 3. 16:47
728x90
반응형

문제링크 : https://codeup.kr/problem.php?id=3120 

 

리모컨

현재 온도a 와 목표 온도b가 입력된다. ( 0 <= a , b <= 40 )

codeup.kr

문제설명

컴퓨터실에서 수업 중인 정보 선생님은 냉난방기의 온도를 조절하려고 한다.
냉난방기가 멀리 있어서 리모컨으로 조작하려고 하는데, 리모컨의 온도 조절 버튼은 다음과 같다.
1) 온도를 1도 올리는 버튼
2) 온도를 1도 내리는 버튼
3) 온도를 5도 올리는 버튼
4) 온도를 5도 내리는 버튼
5) 온도를 10도 올리는 버튼
6) 온도를 10도 내리는 버튼
이와 같이 총 6개의 버튼으로 목표 온도를 조절해야 한다.
현재 설정 온도와 변경하고자하는 목표 온도가 주어지면 이 버튼들을 이용하여 목표 온도로 변경하고자 한다.
이 때 버튼 누름의 최소 횟수를 구하시오.
예를 들어, 7도에서 34도로 변경하는 경우,
7 -> 17 -> 27 -> 32 -> 33 -> 34
이렇게 총 5번 누르면 된다.

입력

현재 온도a 와 목표 온도b가 입력된다. ( 0 <= a , b <= 40 )

출력

최소한의 버튼 사용으로 목표온도가 되는 버튼의 횟수를 출력한다.


문제풀이

1이 되려면 +1 (1회)
2가 되려면 +1, +1 (2회)
3이 되려면 +5, -1, -1 (3회), 또는 +1, +1, +1(3회)
4가 되려면 +5, -1 (2회)
5가 되려면 +5 (1회)
6이 되려면 +5, +1 (2회)
7이 되려면 +5, +1, +1 (3회)
8이 되려면 +10, -1, -1 (3회)
9가 되려면 +10, -1 (2회)
 
cur, target = map(int, (input().split()))

result = 0

result += abs(cur-target)//10
c = abs(cur-target) % 10

if (c==1 or c==5):
    result += 1
elif (c==2 or c==4 or c==6 or c==9):
    result += 2
elif (c==3 or c==7 or c==8):
    result += 3

print(result)
728x90
반응형