-
[백준/BOJ] 1145번 : 적어도 대부분의 배수 (JAVA / 자바)백준 2022. 2. 12. 23:35
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1145
- 문제 -
난이도 브론즈 1 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
노가다 식으로 풀었다. 1부터 시작해서 입력값중 3개이상이 나누어 떨어질때까지 반복문을 돌려서 나누어떨어질때 반복문을 종료하고 그 값을 출력한다.
-풀이-
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)); //입력값들을 저장해줄 배열 선언 int[] arr = new int[5]; //몇개의 입력값이 나누어 떨어지는지 체크할 변수 int count = 0; //결과값을 저장할 변수 int N = 0; StringTokenizer st = new StringTokenizer(br.readLine()); for(int i = 0; i < 5; i++) { arr[i] = Integer.parseInt(st.nextToken()); } //몇에서 3개이상이 나눠질지 모르기 때문에 무한루프 while(true) { N++; //N값을 나눴을때 입력값들이 나누어 떨어지면 count +1 for(int i = 0; i < 5; i++) { if(N >= arr[i] && N % arr[i] == 0) count++; } //3개이상 나눠지면 무한루프 종료 if(count > 2) break; //3개이상 나눠지지 않았으면 count 초기화 count = 0; } System.out.println(N); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 10834번 : 벨트 (JAVA / 자바) (0) 2022.02.13 [백준/BOJ] 1010번 : 다리 놓기 (JAVA / 자바) (6) 2022.02.13 [백준/BOJ] 1110번 : 더하기 사이클 (JAVA / 자바) (0) 2022.02.12 [백준/BOJ] 1032번 : 명령 프롬프트 (JAVA / 자바) (0) 2022.02.12 [백준/BOJ] 1100번 : 하얀 칸 (JAVA / 자바) (0) 2022.02.12