Notice
Recent Posts
Recent Comments
Link
- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 백준 JAVA
- PostgreSQL
- 백준 java jaekjoon JAVA
- linux
- jsonb select
- Rocky Linux 9
- 백준
- jenkins
- subversion
- baekjoon
- available plugins
- poll scm
- rocky linux
- javascript
- java
- 자바
- tomcat-users.xml
- 제수가 0입니다
- 메뉴얼
- putty
- boj
- SVN
- 환경번수
- bekjoon
- ora-01476
- jaekjoon java
- 사용법
- 1773번
- 서버 접근
- DBeaver
Archives
기록하는 개발자
[백준 1769번] 3의 배수 - JAVA 알고리즘 본문
1769번 |
문제 | |
문제가 잘 풀리지 않을 때, 문제를 바라보는 시각을 조금만 다르게 가지면 문제가 쉽게 풀리는 경험을 종종 해 보았을 것이다. 여러 가지 방법이 있지만 그 중 하나로 우리가 풀고 싶은 문제를 좀 더 쉬운 문제로 바꾸어 풀어 보는 방법이 있다. 소위 "다른 문제로 바꾸어 풀기"라는 이 방법은, 아래와 같은 과정으로 이루어진다.
문제 1. "양의 정수 X는 3의 배수인가?" 이 문제를 아래와 같이 변환하는데, X의 각 자리의 수를 단순히 더한 수 Y를 만든다. 예를 들어 X가 1107이었다면, Y는 1+1+0+7=9가 된다. 그리고 Y에 대해서, 아래와 같은 문제를 생각한다. 문제 2. "Y는 3의 배수인가?" 위의 문제 1의 답은 아래의 문제 2의 대답과 일치한다. 위의 예의 경우, Y=9는 3의 배수이므로 X=1107 역시 3의 배수가 되는 것이다. 214는 각 자리수의 합 2+1+4=7이 3의 배수가 아니므로 3의 배수가 아니다. 문제 1을 풀고 싶으면 문제 2로 변환을 해서 문제 2의 답을 문제 1의 답으로 삼으면 된다. 일반적으로 Y는 X보다 크기가 작으므로, 문제 2가 더 쉬운 문제가 된다. 당신이 알고 있는 3의 배수는 한 자리 수밖에 없다고 가정하자. 즉, 문제 변환의 과정을 여러 번 거치다 보면 Y가 한 자리 수가 되는 순간이 있게 되는데, 그렇게 될 때까지 문제 변환을 반복한다는 뜻이다. 변환 후의 Y가 3, 6, 9 중 하나이면 원래의 수 X는 3의 배수이고, Y가 1, 2, 4, 5, 7, 8 중 하나이면 원래의 수 X는 3의 배수가 아니다. 큰 수 X가 주어졌을 때, 앞에서 설명한 문제 변환의 과정을 몇 번 거쳐야 Y가 한 자리 수가 되어, X가 3의 배수인지 아닌지를 알 수 있게 될지를 구하는 프로그램을 작성하시오. |
|
입력 | |
첫째 줄에 큰 자연수 X가 주어진다. X는 1,000,000자리 이하의 수이다. 수는 0으로 시작하지 않는다. | |
출력 | |
첫째 줄에 문제 변환의 과정을 몇 번 거쳤는지를 출력한다. 이 수는 음이 아닌 정수가 되어야 한다. 둘째 줄에는 주어진 수가 3의 배수이면 YES, 아니면 NO를 출력한다. | |
예제 입력 | 예제 출력 |
1234567 | 3 NO |
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class Main {
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); // 선언
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); // 선언
//==========1.숫자를 입력한다.=========
String num = br.readLine(); //숫자를 받아온다.
int num2 = 0; //자리수 더한 값을 담는다
int count = 0; //반복 횟수
//==========2.반복문 시작=========
while(true) {
if(num.length() == 1) { //받아온 숫자가 한자리수가 될때까지 반복한다.
break; //반복문 종료
}
for(int i = 0; i < num.length(); i++) { //받아온 숫자의 자리수를 모두 더한다.
num2 += Integer.parseInt(String.valueOf(num.charAt(i)));
}
count++;
num = String.valueOf(num2); // 변환 결과를 x에 넣어줌
num2 = 0;
}
bw.write(count+"\n");
if(Integer.parseInt(num)%3==0) { //3의 배수인지 확인한다.
bw.write("YES");
}else {
bw.write("NO");
}
bw.close();
br.close();
}
}
개인적으로 정리한 내용을 간단하게 풀어 작성했습니다. 이해가 안가는 부분은 댓글 남겨주시면 설명해드리겠습니다. |
'Baekjoon Online Judge' 카테고리의 다른 글
[백준 3062번] 수 뒤집기 - JAVA 알고리즘 (0) | 2022.04.26 |
---|---|
[백준 2609번] 최대공약수와 최소공배수 - JAVA 알고리즘 (0) | 2022.04.08 |
[백준 2493번] 탑 - JAVA 알고리즘 (0) | 2022.04.05 |
[백준 2860번] 종이에 숫자 쓰기 - JAVA 알고리즘 (0) | 2022.04.01 |
[백준 1452번] 방 번호 - JAVA 알고리즘 (0) | 2022.04.01 |
Comments