Post

[백준] 5622번 - 다이얼 [Java][C++]

[백준] 5622번 - 다이얼 [Java][C++]

문제 링크


1. 문제 풀이

주어진 문자열에 대해 전화를 거는데 걸리는 최소 시간을 구하는 문제로 각 알파벳 별로 몇 초가 걸리는지 미리 배열에 저장한 후 조회하는 방식으로 해결했다.


2. 코드

1. 구현 [Java]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import java.io.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        String str = br.readLine();
        int[] arr = {3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10};
        int sum = 0;

        for (char c : str.toCharArray()) {
            sum += arr[c - 'A'];
        }

        System.out.println(sum);
    }
}

2. 구현 [C++]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    string s;
    cin >> s;

    int arr[26] = {3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8, 8, 9, 9, 9, 10, 10, 10, 10};
    int sum = 0;

    for (char c : s) {
        sum += arr[c - 'A'];
    }

    cout << sum;
}

3. 풀이 정보

1. 구현 [Java]

언어시간메모리코드 길이
Java 11100 ms14160 KB476 B

2. 구현 [C++]

언어시간메모리코드 길이
C++ 170 ms2024 KB343 B

This post is licensed under CC BY 4.0 by the author.