본문 바로가기

백준 문제 풀기/while

백준 while문 단계별 풀기 - 1110번

반응형

입력받은 숫자 26

a의 값: 몫(2)

b의 값: 나머지(6)

c 의값 몫 + 나머지 2 + 6 = 8;

check = 6 * 10(b * 10) + 8(c)

반복

 

import java.util.Scanner;

public class Main2 {
//	0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고
//	, 각 자리의 숫자를 더한다. 그 다음, 주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙이면 새로운 수를 만들 수 있다.
//	다음 예를 보자.
//
//	26부터 시작한다. 2+6 = 8이다. 새로운 수는 68이다. 6+8 = 14이다. 새로운 수는 84이다. 8+4 = 12이다. 새로운 수는 42이다. 4+2 = 6이다. 새로운 수는 26이다.
//
//	위의 예는 4번만에 원래 수로 돌아올 수 있다. 따라서 26의 사이클의 길이는 4이다.
//
//	N이 주어졌을 때, N의 사이클의 길이를 구하는 프로그램을 작성하시오.
//
//	입력
//	첫째 줄에 N이 주어진다. N은 0보다 크거나 같고, 99보다 작거나 같은 정수이다.
//
//	출력
//	첫째 줄에 N의 사이클 길이를 출력한다.
//	x
//	26 
//	2 + 6  = 8;
//	
//	수 = 68;
//	6 + 8 = 14 ;
//	
//	수 = 84;
//	8 + 4 = 12;
//	
//	수 = 42;
//	4 + 2 = 6;
//	
//	수 = 26
//	while(true) {

	public static void main(String[] args) {

		Scanner scanner = new Scanner(System.in);
		int num = scanner.nextInt();
		int check = num;
		int count = 1;

		while (true) {
			int a = check / 10;
			int b = check % 10;
			int c = a + b;
			check = b * 10 + c % 10;
			if (num == check) {
				break;
			} else {
				count++;
			}

		}
		System.out.println(count);

//		}
	}
}

반응형

'백준 문제 풀기 > while' 카테고리의 다른 글

백준 while문 단계별 풀기 - 10871번  (0) 2019.12.01