티스토리 뷰

반응형

 - 백준 알고리즘  : https://www.acmicpc.net/problem

문제

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

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

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

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

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

입력

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

출력

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


예제 입력

  • UNUCIC

예제 출력

  • 36


곰가드의 코드

  • s = ['abc','def','ghi','jkl','mno','pqrs','tuv','wxyz']

    a = input().lower()

    res = 0

    for j in range(len(a)):

        for i in s:

            if a[j] in i:

                res += s.index(i)+3

    print(res)

참고할 파이썬 코드

  • 리스트를 for 문에서 돌리는 방법

    • s = ['abc' , 'bcd']

    • for i in s:

      • print(i)

      •  - > i = 'abc', 'bcd'

  • 리스트의 인덱스를 참조하는 방법

    • s.index('abc') -> 0

    • s.index('aaa') -> ValueError: 'aaa' is not in list         

    • #없는 것을 찾을 땐 에러발생



반응형
댓글
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/11   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
글 보관함