본문 바로가기

Problem Solving/Baekjoon Online Judge

<문자열> 5622번 다이얼 with 파이썬

 

문제

전화를 걸고 싶은 번호가 있다면, 숫자를 하나를 누른 다음에 금속 핀이 있는 곳 까지 시계방향으로 돌려야 한다. 숫자를 하나 누르면 다이얼이 처음 위치로 돌아가고, 다음 숫자를 누르려면 다이얼을 처음 위치에서 다시 돌려야 한다.

숫자 1을 걸려면 총 2초가 필요하다. 1보다 큰 수를 거는데 걸리는 시간은 이보다 더 걸리며, 한 칸 옆에 있는 숫자를 걸기 위해선 1초씩 더 걸린다.

상근이의 할머니는 전화 번호를 각 숫자에 해당하는 문자로 외운다. 즉, 어떤 단어를 걸 때, 각 알파벳에 해당하는 숫자를 걸면 된다. 예를 들어, UNUCIC는 868242와 같다.

할머니가 외운 단어가 주어졌을 때, 이 전화를 걸기 위해서 필요한 시간을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 알파벳 대문자로 이루어진 단어가 주어진다. 단어는 2글자~15글자로 이루어져 있다.

출력

첫째 줄에 다이얼을 걸기 위해서 필요한 시간을 출력한다.

정답비율

57.113%

 

d = dict()
d['A'] = d['B'] = d['C'] = 2
d['D'] = d['E'] = d['F'] = 3
d['G'] = d['H'] = d['I'] = 4
d['J'] = d['K'] = d['L'] = 5
d['M'] = d['N'] = d['O'] = 6
d['P'] = d['Q'] = d['R'] = d['S'] = 7
d['T'] = d['U'] = d['V'] = 8
d['W'] = d['X'] = d['Y'] = d['Z'] = 9

x = input()
time = 0
for i in x :
    time += (d[i] + 1)
print(time)

 

 딕셔너리를 이용하여 문제의 그림에 나와있는대로 알파벳과 다이얼을 각각 키와 값으로 연결시켜 주었다. 위의 코드를 실행하여 딕셔너리를 확인하면 {'A': 2, 'B': 2, 'C': 2, 'D': 3, · · · , 'X': 9, 'Y': 9, 'Z': 9} 와 같다.

  

 1을 걸 때 2초이고 다른 숫자를 걸 때는 한 칸당 1초라고 했으므로 숫자의 +1초가 걸린다는 것을 알 수 있다. 

 

 

 


 

참고

 

 

5622번: 다이얼

첫째 줄에 알파벳 대문자로 이루어진 단어가 주어진다. 단어는 2글자~15글자로 이루어져 있다.

www.acmicpc.net