Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- EC2
- java
- 라우터
- nodejs
- 리액트
- 정렬
- Router
- ELB
- spring
- BFS
- react
- EventListener
- 서버구축
- 알고리즘
- 동적프로그래밍
- mysql
- 스터디
- AWS
- 브루트포스
- 백준알고리즘
- Spring Boot
- 자료구조
- 백준
- 다익스트라 알고리즘
- 토이프로젝트
- url parsing
- 완전탐색
- Algorithm
- 탐욕법
- sort
Archives
- Today
- Total
공부하는 블로그
Baekjoon | Q.5622 - 다이얼 본문
5622번: 다이얼
문제 상근이의 할머니는 아래 그림과 같이 오래된 다이얼 전화기를 사용한다. 전화를 걸고 싶은 번호가 있다면, 숫자를 하나를 누른 다음에 금속 핀이 있는 곳 까지 시계방향으로 돌려야 한다. 숫자를 하나 누르면 다이얼이 처음 위치로 돌아가고, 다음 숫자를 누르려면 다이얼을 처음 위치에서 다시 돌려야 한다. 숫자 1을 걸려면 총 2초가 필요하다. 1보다 큰 수를 거는데 걸리는 시간은 이보다 더 걸리며, 한 칸 옆에 있는 숫자를 걸기 위해선 1초씩 더 걸린다.
www.acmicpc.net
해당하는 문자열에 알맞은 다이얼을 입력하여 총 입력 시간을 구하는 문제이다.
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String alpha = sc.nextLine();
int time = 0;
for (int i = 0; i < alpha.length(); i++) {
int asc = alpha.charAt(i);
if(asc >= 65 && asc < 68) {
time += 3;
}else if(asc >= 68 && asc < 71) {
time += 4;
}else if(asc >= 71 && asc < 74) {
time += 5;
}else if(asc >= 74 && asc < 77) {
time += 6;
}else if(asc >= 77 && asc < 80) {
time += 7;
}else if(asc >= 80 && asc < 84) {
time += 8;
}else if(asc >= 84 && asc < 87) {
time += 9;
}else if(asc >= 87 && asc < 91) {
time += 10;
}
}
System.out.println(time);
}
}
각각의 문자를 아스키코드로 변환하여 풀었다.
'알고리즘 공부' 카테고리의 다른 글
Baekjoon | Q.10250 - ACM 호텔 (0) | 2019.12.26 |
---|---|
Baekjoon | Q.1316 - 그룹 단어 체커 (0) | 2019.12.23 |
Baekjoon | Q.1065 - 한수 (0) | 2019.12.22 |
Baekjoon | Q.15596 - 정수 N개의 합 (0) | 2019.12.22 |
Baekjoon | Q.4344 - 평균은 넘겠지 (0) | 2019.12.21 |
Comments