본문 바로가기

C++/백준

[C++][백준] 5622 다이얼

https://www.acmicpc.net/problem/5622

 

5622번: 다이얼

문제 상근이의 할머니는 아래 그림과 같이 오래된 다이얼 전화기를 사용한다. 전화를 걸고 싶은 번호가 있다면, 숫자를 하나를 누른 다음에 금속 핀이 있는 곳 까지 시계방향으로 돌려야 한다. 숫자를 하나 누르면 다이얼이 처음 위치로 돌아가고, 다음 숫자를 누르려면 다이얼을 처음 위치에서 다시 돌려야 한다. 숫자 1을 걸려면 총 2초가 필요하다. 1보다 큰 수를 거는데 걸리는 시간은 이보다 더 걸리며, 한 칸 옆에 있는 숫자를 걸기 위해선 1초씩 더 걸린다.

www.acmicpc.net

문제

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

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

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

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

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

입력

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

출력

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

예제 입력 1

UNUCIC

예제 출력 1

36

 

풀이

조건에 맞게 각 알파벳에 알맞은 숫자를 sec에 더해줘서 구할 수 있다.

 

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
31
32
33
34
35
#include <stdio.h>
#include <stdlib.h>
#include <cstring>
int main(){
    char num[15];
    int sec=0;
    scanf("%s",num);
    int size = strlen(num);
    for(int i=0; i<size; i++){
        if(num[i]>=65 && num[i]<=67)
            sec+=3;
        else if(num[i]>=68 && num[i]<=70)
            sec+=4;
        else if(num[i]>=71 && num[i]<=73)
            sec+=5;
        else if(num[i]>=74 && num[i]<=76)
            sec+=6;
        else if(num[i]>=77 && num[i]<=79)
            sec+=7;
        else if(num[i]>=80 && num[i]<=83)
            sec+=8;
        else if(num[i]>=84 && num[i]<=86)
            sec+=9;
        else if(num[i]>=87 && num[i]<=90)
            sec+=10;
        else if(num[i]==1)
            sec+=2;
        else
            sec+=11;
    }
 
    printf("%d\n",sec);
 
}
http://colorscripter.com/info#e" target="_blank" style="color:#4f4f4ftext-decoration:none">Colored by Color Scripter
 

'C++ > 백준' 카테고리의 다른 글

[C++][백준] 8393 합  (0) 2020.03.11
[C++][백준] [BFS] 7576 토마토  (0) 2020.03.11
[C++][백준] [정렬] 5544 리그  (0) 2020.03.11
[C++][백준] 4948 베르트랑 공준  (0) 2020.03.11
[C++][백준] 4673 셀프 넘버  (0) 2020.03.10