[백준/BOJ] 1864번 : 문어 숫자 (JAVA / 자바)
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1864
1864번: 문어 숫자
해류가 매우 느리고 바닥을 기어다니는 생물이 적은 바다 밑바닥에서만 발견되는 잔물결 무늬의 정체는 오랫동안 해양학자들에게 수수께끼였다. 하지만 최근의 연구 성과는 동물 언어학 분야
www.acmicpc.net
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
(JAVA / 자바) Scanner 와 Bufferedreader
안녕하세요~ 코딩하는 코알못 코메인입니다. 이번엔 백준 문제 풀면서 계속 언급될 scanner와 bufferedreader에 대한 간단한 정리를 해볼거다. 자바에서 입력은 scanner와 bufferedreader가 있다. 우선 각자
comain.tistory.com
풀이 방법
문자열 입력 후 문자열을 charAt으로 하나 씩 뽑고 문제에서 알려준 방식으로 10진수로 바꿔준다.
if문이나 switch문으로 문자판별 조건으로 구한다. 크게 어렵진 않으니 코드로 보자.
-풀이-
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
//반복 횟수가 따로 정해져있지 않으니 무한루프 사용
while(true) {
String S = br.readLine();
//10진수로 바꾼 값을 저장할 변수 선언
int result = 0;
//문자열 길이를 int 변수에 저장
int n = S.length();
//#이 오면 반복문 종료
if(S.equals("#")) {
break;
}
//문자열 0인덱스 자리부터 어떤 문자가 오는지에 따른 값 저장
for(int i = 0; i < n; i++) {
if(S.charAt(i) == '-') {
result += 0 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '\\') {
result += 1 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '(') {
result += 2 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '@') {
result += 3 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '?') {
result += 4 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '>') {
result += 5 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '&') {
result += 6 * Math.pow(8, ((n - 1) - i));
}else if(S.charAt(i) == '%') {
result += 7 * Math.pow(8, ((n - 1) - i));
}else {
result += -1 * Math.pow(8, ((n - 1) - i));
}
}
System.out.println(result);
}
}
}
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠다.