-
[백준/BOJ] 11034번 : 캥거루 세마리2 (JAVA / 자바)백준 2022. 2. 18. 22:18
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/11034
11034번: 캥거루 세마리2
여러개의 테스트 케이스로 이루어져 있으며, 세 캥거루의 초기 위치 A, B, C가 주어진다. (0 < A < B < C < 100)
www.acmicpc.net
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
(JAVA / 자바) Scanner 와 Bufferedreader
안녕하세요~ 코딩하는 코알못 코메인입니다. 이번엔 백준 문제 풀면서 계속 언급될 scanner와 bufferedreader에 대한 간단한 정리를 해볼거다. 자바에서 입력은 scanner와 bufferedreader가 있다. 우선 각자
comain.tistory.com
풀이 방법
https://comain.tistory.com/103
[백준/BOJ] 2965번 : 캥거루 세마리 (JAVA / 자바)
안녕하세요~ 코딩하는 코알못 코메인입니다. https://www.acmicpc.net/problem/2965 2965번: 캥거루 세마리 첫째 줄에 세 캥거루의 초기 위치 A, B, C가 주어진다. (0 < A < B < C < 100) www.acmicpc.net - 문제..
comain.tistory.com
똑같은 문제이다. 다른 점은 입력을 계속 받을 수 있기 때문에 반복문으로 원하는 만큼 입력받고 출력해줘야 한다는 것이다. 하지만 보며 테스트 케이스가 주어지지 않았다. 테스트 케이스의 수가 정해지지 않았기 때문에 무한루프를 사용해야하는데, 무한루프를 종료시킬 조건도 주어지지가 않았다. 그렇다고 그냥 무한루프로 돌리면 EOF에러 또는 nullpointer에러가 뜰 것이다. 보통 nullpointer는 try catch로 예외처리를 해주는데, 필자는 그냥 EOF에러 해결 방식으로 풀었다.
-EOF에러 해결-
scanner일경우엔 while문 조건에 scan.hasnext를 입력하면 되고, BufferedReader는 while문 조건에 와일문 밖에서 BufferedReader를 받을 문자열 변수를 선언하고, 그 변수를 조건부근에서 입력값을 받는다. 그리고 그 입력값이 null이 아닐 경우에만 반복문을 진행한다는 조건을 추가한다. 그리고 밑에 StringTokenizer가 오든 머가 오든 받는 값을 입력받은 문자열로 받으면 된다.
Scanner와 BufferedReader와 두가지가 방식이 다른 이유는 Scanner는 자체적으로 scan.hasnext라는 메소드 내장 함수가 있기 때문에 그냥 저걸 입력하면 처리가 되는 것이고, BufferedReader는 그런 내장 함수가 없기 때문에 직접 null처리를 해줘야하는 것이다.
캥거루 세마리 문제의 코드를 무한루프에 집어 넣자.
코드로 보자.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.StringTokenizer; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String S; //null 값 처리 while((S = br.readLine()) != null) { StringTokenizer st = new StringTokenizer(S); int A = Integer.parseInt(st.nextToken()); int B = Integer.parseInt(st.nextToken()); int C = Integer.parseInt(st.nextToken()); //A부터 B, B부터 C까지의 두 거리중 더 큰 값을 구한다. int max = Math.max((B - A), (C - B)); System.out.println(max); } } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 1371번 : 가장 많은 글자 (JAVA / 자바) (0) 2022.02.19 [백준/BOJ] 1362번 : 펫 (JAVA / 자바) (0) 2022.02.19 [백준/BOJ] 11024번 : 더하기 4 (JAVA / 자바) (0) 2022.02.18 [백준/BOJ] 11023번 : 더하기 3 (JAVA / 자바) (0) 2022.02.18 [백준/BOJ] 1384번 : 메시지 (JAVA / 자바) (0) 2022.02.18