2021.11.06 백준 문제풀이
2021.11.06. 백준 문제풀이
5622번 다이얼 (Bronze 2)
문제
https://www.acmicpc.net/problem/5622
전화를 걸고 싶은 번호가 있다면, 숫자를 하나를 누른 다음에 금속 핀이 있는 곳 까지 시계방향으로 돌려야 한다. 숫자를 하나 누르면 다이얼이 처음 위치로 돌아가고, 다음 숫자를 누르려면 다이얼을 처음 위치에서 다시 돌려야 한다.
숫자 1을 걸려면 총 2초가 필요하다. 1보다 큰 수를 거는데 걸리는 시간은 이보다 더 걸리며, 한 칸 옆에 있는 숫자를 걸기 위해선 1초씩 더 걸린다.
상근이의 할머니는 전화 번호를 각 숫자에 해당하는 문자로 외운다. 즉, 어떤 단어를 걸 때, 각 알파벳에 해당하는 숫자를 걸면 된다. 예를 들어, UNUCIC는 868242와 같다.
할머니가 외운 단어가 주어졌을 때, 이 전화를 걸기 위해서 필요한 최소 시간을 구하는 프로그램을 작성하시오.
풀이
문자를 나눠서 각 문자를 비교할 수도 있었지만, 아스키 코드로 변환 후 대소비교를 하는 것이 더 도움이 될 것이라고 생각했다.
처음에는 숫자와 문자 사이에 규칙을 찾아서 반복문을 쓰고 싶었지만 PQRS와 WXYZ 같은 문자들 때문에 괜히 꼬일 것 같아서 단순히 조건문만 사용했다.
소스코드
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 | const fs = require("fs"); const input = fs.readFileSync("/dev/stdin").toString().trim().split(""); let answer = 0; input.forEach((str) => { if (str.charCodeAt(0) <= 67) { answer += 3; } else if (str.charCodeAt(0) <= 70) { answer += 4; } else if (str.charCodeAt(0) <= 73) { answer += 5; } else if (str.charCodeAt(0) <= 76) { answer += 6; } else if (str.charCodeAt(0) <= 79) { answer += 7; } else if (str.charCodeAt(0) <= 83) { answer += 8; } else if (str.charCodeAt(0) <= 86) { answer += 9; } else if (str.charCodeAt(0) <= 90) { answer += 10; } }); console.log(answer); |