-
[백준/BOJ] 1110번 : 더하기 사이클 (JAVA / 자바)백준 2022. 2. 12. 23:05
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1110
1110번: 더하기 사이클
0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고, 각 자리의 숫자를 더한다. 그 다음,
www.acmicpc.net
- 문제 -
난이도 브론즈 1 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
(JAVA / 자바) Scanner 와 Bufferedreader
안녕하세요~ 코딩하는 코알못 코메인입니다. 이번엔 백준 문제 풀면서 계속 언급될 scanner와 bufferedreader에 대한 간단한 정리를 해볼거다. 자바에서 입력은 scanner와 bufferedreader가 있다. 우선 각자
comain.tistory.com
풀이 방법
입력값이 26이면 2 + 6 = 8, 68이고 6 + 8 = 14이런식으로 간다고 한다.
입력값 26이 N이면 다음 값인 68에서 60에 해당하는 값은 ((N % 10) * 10)이고, 8에 해당하는 값은(((N / 10) + (N % 10)) % 10)이다. 두 값을 더하면 68에 해당하는 연산 값이 나오는 것이다. 그 값을 N에 다시 저장한 뒤, 연산을 반복한다. 반복해서 나온 N 값이 최초 N값과 같아지면 반복을 그만두고, 반복 횟수를 출력한다.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int N = Integer.parseInt(br.readLine()); //입력값을 나중에 비교하기 위해 새로운 변수에 저장해둔다. int n = N; //반복횟수를 체크하기 위한 변수 선언 int count = 0; //반복 횟수를 할 수 없기 때문에 무한루프 while(true) { //연산 후 N에 저장 N = ((N % 10) * 10) + (((N / 10) + (N % 10)) % 10); //반복될때마다 count +1 count++; //연산 값이 처음 입력값을 저장해둔 값과 같아지면 무한루프 종료 if(N == n) break; } System.out.println(count); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 1010번 : 다리 놓기 (JAVA / 자바) (6) 2022.02.13 [백준/BOJ] 1145번 : 적어도 대부분의 배수 (JAVA / 자바) (0) 2022.02.12 [백준/BOJ] 1032번 : 명령 프롬프트 (JAVA / 자바) (0) 2022.02.12 [백준/BOJ] 1100번 : 하얀 칸 (JAVA / 자바) (0) 2022.02.12 [백준/BOJ] 1076번 : 저항 (JAVA / 자바) (0) 2022.02.12