내용으로 건너뛰기
테페리넷
사용자 도구
등록
로그인
사이트 도구
검색
도구
문서 보기
Fold/unfold all
역링크
미디어 관리자
사이트맵
등록
로그인
>
미디어 관리자
사이트맵
현재 위치:
테페리넷
»
Problem Solving
»
문제
»
프로그래머스
»
약수의 합
ps:problems:programmers:12928
이 문서는 읽기 전용입니다. 원본을 볼 수는 있지만 바꿀 수는 없습니다. 문제가 있다고 생각하면 관리자에게 문의하세요.
====== 약수의 합 ====== ===== 풀이 ===== * 어떤 수의 모든 약수의 합을 구하는 것은, 그냥 모든 약수를 다 구해서 더하는 것이 가장 평범하고 빠르다. * [[ps:정수론적 함수]] 참고. * i를 1부터 sqrt(n)까지 증가시키면서, n이 i로 나누어 떨어지면 i와 n/i 는 모두 n의 약수이다. * i가 sqrt(n)일 경우에는 i와 n/i 가 같으므로 중복해서 더하지 않도록 주의할것. * 시간 복잡도는 O(sqrt(n)). ===== 코드 ===== <dkpr py> """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 </dkpr> {{tag>프로그래머스 ps:problems:programmers:Level_1}}
ps/problems/programmers/12928.txt
· 마지막으로 수정됨: 2021/06/10 14:18 저자
teferi
문서 도구
문서 보기
역링크
Fold/unfold all
맨 위로