-
[백준/BOJ] 7789번 : 텔레프라임 (JAVA / 자바)백준 2022. 2. 7. 20:22
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/7789
7789번: 텔레프라임
소수를 매우 좋아하는 수학자가 있다. 이 수학자는 매번 전화번호를 받을 때 마다, 그 전화번호가 소수인지 아닌지를 검사한다. 수학자는 자신의 모든 친구의 전화번호가 소수인지 아닌지를 기
www.acmicpc.net
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
(JAVA / 자바) Scanner 와 Bufferedreader
안녕하세요~ 코딩하는 코알못 코메인입니다. 이번엔 백준 문제 풀면서 계속 언급될 scanner와 bufferedreader에 대한 간단한 정리를 해볼거다. 자바에서 입력은 scanner와 bufferedreader가 있다. 우선 각자
comain.tistory.com
풀이 방법
소수 관련 문제지만 딱히 소수를 구하라는 문제가 아니기 때문에 쉬운 문제다.
두 입력값 첫번째 입력값을 A라고 하겠다. 두번째 입력값과 A를문자열 형변환해서 B값에 저장한다.
그리고 반복문(입력값을 하는 확인하는 것보다 무한루프로 돌려서 조건을 만족할때 종료 시키는게 더 낫다 생각해 무한루프 사용)에 A와 B를 2부터 자신의 값보다 -1까지 나눠준다. 그렇게 나눠서 나머지가 0이 되면 무한루프를 종료시키고No를 출력, 누눠주는 값이 A보다 큰 B값이 되면 종료시키고 Yes를 출력.
-풀이-
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)); StringTokenizer st = new StringTokenizer(br.readLine()); int A = Integer.parseInt(st.nextToken()); int B = Integer.parseInt(st.nextToken() + String.valueOf(A)); //나눠줄 변수 int i = 2; //결과값을 저장할 변수 String S = ""; //무한루프 while(true) { if(i < A && A % i == 0) { S = "No"; break; } if(i < B && B % i == 0) { S = "No"; break; } //나눠줄 변수에 반복될때마다 1씩 더한다. i++; //나너줄 변수가 B값과 같아지면 종료 if(i == B) { S = "Yes"; break; } } System.out.println(S); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 8932번 : 7종 경기 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 9063번 : 대지 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 7770번 : 아즈텍 피라미드 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 7510번 : 고급 수학 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 6609번 : 모기곱셈 (JAVA / 자바) (0) 2022.02.07