Algorithm/백준

[Python] 백준 단계별로 풀어보기: 4단계 while문

nayoungs 2022. 2. 11. 18:09
728x90

<1단계:10952>

 

두 정수 A,B를 입력받고 , A+B를 출력하는 프로그램을 작성해보자.

입력은 여려 개의 테스트 케이스로 이루어지고, 각 테스트 케이스는 한 줄로 이루어져있다.

각 줄에 A,B가 입력되고, 입력의 마지막에는 0두개를 입력한다.

각 테스트 케이스마다 A+B를 출력하자.

 

코드:

while True:
    A,B=map(int,input().split())
    if A == 0 and B == 0:
        break
    print(A+B)
 

입력:

1 1
2 3
3 4
9 8
5 2
0 0
 

출력:

2
5
7
17
7
 

 

 

 


 

 

<2단계:10951>

 

두 정수 A,B를 입력받은 다음 A+B를 출력하는 프로그램을 작성해보자.

각 테스트 케이스는 한 줄로 이루어져있으며, 각 줄에 A와 B가 주어진다.

각 테스트 케이스마다 A+B를 출력하자.

 

코드:

while True:
    try:
        A,B=map(int,input().split())
        print(A+B)
    except:
        break
 

입력:

1 1
2 3
3 4
9 8
5 2
 

출력:

2
5
7
17
7
 

 

 


 

 

<3단계:1110>

 

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의 사이클의 길이를 구하는 프로그램을 작성해보자.

 

while문을 무한루프로 돌려주는데,

ten에는 입력받은 숫자의 몫(//)을,

one에는 입력받은 숫자의 나머지(%)를 저장해준다.

total에 ten과 one을 합한 값을 넣어준다.

count를 증가시켜 주고, 파이썬은 문자열로 합하고 int형으로 변환이 가능하기때문에

위와 같이 해준다.

num과 n이 같으면 while문을 빠져나와 준다.

 

코드:

k = n = int(input())
count = 0
while True:
    ten = k//10
    one = k%10
    total = ten + one
    count += 1
    k = int(str(k%10)+str(total%10))
    if (n==k):
        break
print(count)
 

입력:

26
 

출력:

4
 

 

 


 

 

지금까지 백준 단계별로 풀어보기 4단계를 풀어보았다.

 

출처: https://www.acmicpc.net/step

 

 

 

728x90