반응형
문제: https://www.acmicpc.net/problem/4375
풀이:
이 문제는 1, 11, 111, 1111와 같이 1로 이루어진 수들로 나누어 떨어지는 수의 자릿수를 찾는 문제입니다.
입력을 무제한으로 받아야하기 때문에 try, except 문을 사용했고 EOF(end of file) 에러가 발생하면 종료되도록 처리해주어야 합니다.
2와 5로 나누어 떨어지지 않는 정수들은 모두 1로 이루어진 수들로 나누어 떨어지기 때문에 나누어 떨어지지 않을 경우를 생각할 필요는 없었고, num에 10을 곱하고 1을 더하는 방법으로 1로 이루어진 수를 무한루프를 돌며 만들어 주었습니다.
정답:
while True:
try:
n = int(input())
if n == 1:
print(1)
continue
num = 1
cnt = 1
while True:
num = (num * 10) + 1
cnt += 1
if (num % n) == 0:
print(num)
break
except EOFError:
break
반응형
'Python 코딩테스트' 카테고리의 다른 글
백준 17452 약수의합 파이썬(python) (0) | 2022.01.17 |
---|---|
수학: 백준 17427 약수의 합 2 파이썬(python) (0) | 2022.01.13 |
수학: 백준 1037 약수 (0) | 2022.01.10 |
그리디: 백준 1080 파이썬 행렬 (0) | 2021.10.07 |
BFS(너비 우선 탐색): 백준 1697 숨바꼭질 (0) | 2021.10.06 |