BAEKJOON 문제 풀이 : 1110번 더하기 사이클
BAEKJOON2020. 2. 9. 22:40
문제 : https://www.acmicpc.net/problem/1110
1110번: 더하기 사이클
0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고, 각 자리의 숫자를 더한다. 그 다음, 주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙이면 새로운 수를 만들 수 있다. 다음 예를 보자. 26부터 시작한다. 2+6 = 8이다. 새로운 수는 68이다. 6+8 = 14이다. 새로운 수는 84이다. 8+4 =
www.acmicpc.net
원하는 값이 나올 때까지 연산을 무한히 반복하면 되는 문제입니다.
문제 풀이는 아래와 같습니다.
1. Java
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
|
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int criterion = Integer.parseInt(br.readLine());
int target = criterion;
int cnt = 1;
while (true) {
int temp = ((target % 10) * 10) + ((target / 10 + target % 10) % 10);
if (criterion == temp)
break;
target = temp;
cnt++;
}
bw.write(cnt + "\n");
bw.close();
br.close();
}
}
|
cs |
2. Python 3
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import sys
if __name__ == '__main__':
criterion = int(sys.stdin.readline())
target = criterion
cnt = 1
while True:
temp = ((target % 10) * 10) + ((target // 10 + target % 10) % 10)
if (criterion == temp):
break;
target = temp;
cnt += 1
print(cnt)
|
cs |
'BAEKJOON' 카테고리의 다른 글
BAEKJOON 문제 풀이 : 2562번 최댓값 (0) | 2020.02.17 |
---|---|
BAEKJOON 문제 풀이 : 10818번 최소, 최대 (0) | 2020.02.13 |
BAEKJOON 문제 풀이 : 10871번 X보다 작은 수 (0) | 2020.02.06 |
BAEKJOON 문제 풀이 : 2439번 별 찍기 - 2 (0) | 2020.02.03 |
BAEKJOON 문제 풀이 : 15552번 빠른 A+B (0) | 2020.01.26 |