-
[백준/BOJ] 9366번 : 삼각형 분류 (JAVA / 자바)백준 2022. 2. 8. 16:55
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/9366
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
세 수의 값의 크기의 순서를 구하기 위해 배열에 저장하고, Arrays.sort로 정렬한다.
조건문으로 세 값의 크기를 비교 후 결과값을 출력한다.
작은 두 값의 합이 제일 큰 수보다 작으면 삼각형이 될 수 없다.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Arrays; import java.util.StringTokenizer; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int T = Integer.parseInt(br.readLine()); //값 개를 저장할 것이기에 크기가 3인 배열 선언 int[] arr = new int[3]; for(int i = 1; i <= T; i++) { StringTokenizer st = new StringTokenizer(br.readLine()); arr[0] = Integer.parseInt(st.nextToken()); arr[1] = Integer.parseInt(st.nextToken()); arr[2] = Integer.parseInt(st.nextToken()); //정렬 Arrays.sort(arr); System.out.print("Case #" + i + ": "); if(arr[0] + arr[1] <= arr[2]) { System.out.println("invalid!"); }else if(arr[0] == arr[1] && arr[1] == arr[2]) { System.out.println("equilateral"); }else if(arr[0] == arr[1] || arr[1] == arr[2]) { System.out.println("isosceles"); }else { System.out.println("scalene"); } } } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 9469번 : 폰 노이만 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 9437번 : 사라진 페이지 찾기 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 9325번 : 얼마? (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 9295번 : 주사위 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 9094번 : 수학적 호기심 (JAVA / 자바) (0) 2022.02.08