nayoungs
항상 끈기있게
nayoungs
  • 분류 전체보기 (275)
    • Cloud (21)
      • AWS (15)
      • Azure (3)
      • NCP (2)
      • GCP (1)
    • DevOps (68)
      • Docker (16)
      • Kubernetes (50)
      • CICD (2)
    • IaC (25)
      • Ansible (17)
      • Terraform (8)
    • Certification (4)
    • 금융 IT (5)
    • AI (3)
    • Linux (47)
    • 미들웨어 (5)
    • Programming (7)
      • GoLang (3)
      • Spring (4)
    • CS (25)
      • 네트워크 (17)
      • 운영체제 (5)
      • Web (1)
      • 개발 상식 (2)
      • 데이터베이스 (0)
    • Algorithm (59)
      • 프로그래머스 (36)
      • 백준 (18)
      • 알고리즘 정리 (5)
    • ETC (6)

블로그 메뉴

  • 홈
  • 방명록

공지사항

인기 글

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
nayoungs

항상 끈기있게

Algorithm/백준

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

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
저작자표시 (새창열림)
    'Algorithm/백준' 카테고리의 다른 글
    • [Python] 백준 단계별로 풀어보기: 6단계 함수
    • [Python] 백준 단계별로 풀어보기: 5단계 1차원 배열
    • [Python] 백준 단계별로 풀어보기: 3단계 for문
    • [Python] 백준 단계별로 풀어보기: 2단계 if문
    nayoungs
    nayoungs
    안되면 될 때까지

    티스토리툴바