| ps | |
|---|---|
| 링크 | programmers.co.kr/… |
| 출처 | 프로그래머스 |
| 문제 번호 | 12928 |
| 문제명 | 약수의 합 |
| 레벨 | Level 1 |
| 분류 |
수학 |
| 시간복잡도 | O(sqrt(n)) |
| 인풋사이즈 | n <= 3000 |
| 사용한 언어 | Python |
| 해결날짜 | 2021/06/08 |
"""Solution code for "Programmers 12928. 약수의 합".
- Problem link: https://programmers.co.kr/learn/courses/30/lessons/12928
- Solution link: http://www.teferi.net/ps/problems/programmers/12928
"""
import math
def solution(n):
sqrt = math.isqrt(n)
answer = sum((i + n // i) for i in range(1, sqrt + 1) if n % i == 0)
if sqrt * sqrt == n:
answer -= sqrt
return answer