문제:
어떤 숫자 n이 자신을 제외한 모든 약수들의 합과 같으면, 그 수를 완전수라고 한다.
예를 들어 6은 6 = 1 + 2 + 3 으로 완전수이다.
n이 완전수인지 아닌지 판단해주는 프로그램을 작성하라.
입력:
입력은 테스트 케이스마다 한 줄 간격으로 n이 주어진다. (2 < n < 100,000)
입력의 마지막엔 -1이 주어진다.
출력:
테스트케이스마다 한줄에 하나씩 출력해야 한다.
n이 완전수라면, n을 n이 아닌 약수들의 합으로 나타내어 출력한다. (예제 출력 참고).
이때, 약수들은 오름차순으로 나열해야 한다.
n이 완전수가 아니라면 n is NOT perfect. 를 출력한다.
풀이방법:
약수들을 찾는 것은 어렵지 않으나 출력 요건을 주의 깊게 맞춰야 하는 문제인 것 같다.
약수들을 찾는 것은 브루트포스 방법으로 2부터 다 나눠보면서 나머지가 없는 값을 찾으면 된다. 이 때, 조금이라도 시간을 줄이기 위해서 n까지 다 나눠보는 것이 아닌 n//2-1까지 나눠보도록 했다. 이렇게 약수들을 모두 찾은 다음에 중복을 제거한 다음에 정렬을 했다. (중복은 제곱수를 위해 제거, 9와 같은 경우 1,3,3과 같이 들어가 있을 것)
약수들의 합이 n과 같으면 완전수이므로 출력 조건에 맞춰서 출력을 하고, 다르면 n is NOT perfect.로 출력한다.
100,000미만의 완전수는 6, 28, 496, 8128만 있으니 확인 후 제출하면 된다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
while True:
n=int(input())
if n==-1:
break
factor=[1]
for i in range(2,int(n//2)):
if n%i==0 and i not in factor:
factor.append(i)
factor.append(n//i)
factor=sorted(list(set(factor)))
answer=""
if sum(factor)==n:
answer += "{} =".format(n)
for i in range(len(factor)):
answer += " {}".format(factor[i])
if (i+1)!=len(factor):
answer+=" +"
else:
answer = "{} is NOT perfect.".format(n)
print(answer)
|
cs |
문제링크:
https://www.acmicpc.net/problem/9506
'Algorithm > Python' 카테고리의 다른 글
[BOJ]10830. 행렬 제곱 (0) | 2020.06.16 |
---|---|
[BOJ]1837. 암호제작 (0) | 2020.06.11 |
[Programmers]2018 Kakao[1차]추석 트래픽 (0) | 2020.05.26 |
[Programmers]2019 Kakao 불량 사용자 (0) | 2020.05.21 |
[BOJ]2468. 안전 영역 (0) | 2020.05.19 |