목차

약수의 합

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