백준

[백준/BOJ] 1864번 : 문어 숫자 (JAVA / 자바)

코메인 2022. 1. 29. 17:48

안녕하세요~ 코딩하는 코알못 코메인입니다.

 

 

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

 

1864번: 문어 숫자

해류가 매우 느리고 바닥을 기어다니는 생물이 적은 바다 밑바닥에서만 발견되는 잔물결 무늬의 정체는 오랫동안 해양학자들에게 수수께끼였다. 하지만 최근의 연구 성과는 동물 언어학 분야

www.acmicpc.net


- 문제 -

 

난이도 브론즈 3 문제이다.

자바에서 입력방식은 scanner와 bufferedreader가 있다.

자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.

bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.

더 자세한 내용은 아래 글 참고 하면 좋다.

https://comain.tistory.com/3

 

(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);
		}
	}

}

-결과-

 


아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠다.