[BOJ/백준-Python]5622번 - 다이얼

5622번 - 다이얼

문제

상근이의 할머니는 아래 그림과 같이 오래된 다이얼 전화기를 사용한다.

dial

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

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

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

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

입력

첫째 줄에 알파벳 대문자로 이루어진 단어가 주어진다. 단어의 길이는 2보다 크거나 같고, 15보다 작거나 같다.

출력

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

예제 입력 1

WA

예제 출력 1

13

예제 입력 2

UNUCIC

예제 출력 2

36

해결할 방법을 생각해보자.💡

알파벳 대문자를 입력받아서 숫자에 빗대어 표현한다. 그리고 다이얼을 보면 알파벳 순서대로 숫자에 대입되어 있는 것을 확인할 수 있다.

2번 : ABC

3번 : DEF

4번 : GHI

5번 : JKL

6번 : MNO

7번 : PQRS

8번 : TUV

9번 : WXYZ

이렇게 순서대로 나눠져 있다. 이것을 우리는 리스트 형태로 만들어 놓자.

dial = ['ABC','DEF','GHI','JKL','MNO','PQRS','TUV','WXYZ']

그리고 우리는 결국 입력받은 문자로 다이얼 돌리는 시간을 출력하는 것이 목표이므로 소비되는 시간을 담기위한 변수를 만들어주자.

spend = 0

이제 문자를 받아주자.(입력 예제가 대문자이므로 따로 upper는 하지 않았음)

S = input()

입력받은 문자열에서 알파벳 하나하나 어떤 다이얼의 숫자인지 알아보기 위해서 반복문을 사용해야한다.

for s in S:

그리고 그 알파벳이 어떤 다이얼에 속해있는지 알기 위해서 dial 리스트와 비교할 것이다.

인덱스를 사용해서 시간을 측정해줄 것이기 때문에 반복문의 범위를 dial 리스트 자체가 아닌 그 길이만큼으로 잡아준다.

	for j in range(len(dial)):

만약에 입력받은 문자열 내의 알파벳 하나가 dial의 원소값 안에 존재한다면, 그 인덱스 값에 3을 더한 값을 시간에 추가해주면 된다. 예를들어 ABC는 2번 다이얼에 존재하고 dial이라는 리스트 안에서는 0번 인덱스에 해당한다. 2번 다이얼을 돌리는데 걸리는 시간은 2 + 1로 3초이기 때문에, 인덱스 j3을 더해준 값을 spend에 더해준다고 생각하면 된다.

		if s in dial[j]:
        	spend += (j+3)

이 과정을 반복하면 총 걸린 시간인 spend를 출력해주면 문제 해결!

print(spend)

코드💻

dial = ['ABC','DEF','GHI','JKL','MNO','PQRS','TUV','WXYZ']
spend = 0
S = input()

for s in S:
    for j in range(len(dial)):
        if s in dial[j]:
            spend += (j+3)

print(spend)

해결 로그

문제 푼 날짜 체크
2022-05-29
   
   
   
   

2022

[web]jQuery 복습 3

1 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]jQuery 복습 2

13 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]jQuery 복습 1

14 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]JavaScript 정리4

5 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]JavaScript 정리3

10 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]JavaScript 정리2

7 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]JavaScript 정리1

8 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]CSS 기초 정리

11 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[web]HTML 기초 정리

8 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

[Pandas]pandas 연습

3 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

맨 위로 이동 ↑

2021

[Python기초]module

1 분 소요

[Noitce] 고쳐야하거나 틀린 것이 있으면 말씀해주세요!

맨 위로 이동 ↑