본문 바로가기

Coding Test

백준 1110번 - while문

문제 : 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과 num이라는 두개의 변수를 설정한다. 

N = num = int(input())
cnt = 0
while True:
    A = num // 10
    B = num % 10
    num = (B*10) + (A+B) % 10
    cnt += 1
    if num == N:
        break
print(cnt)

 

'Coding Test' 카테고리의 다른 글

백준 4344번 - 리스트, %.nf  (0) 2022.03.03
백준 2884번, 2525번 - if문  (0) 2022.02.23
백준 10951번 - while문 탈출  (0) 2022.02.18
백준 8393, 2741, 2742 - for문  (0) 2022.02.17
백준 15552번 - sys.stdin.readline()  (0) 2022.02.13