최대 1 분 소요

1. 문제Permalink

[level 1] 약수의 합 - 12928Permalink

문제 링크

성능 요약Permalink

메모리: 10.2 MB, 시간: 0.15 ms

구분Permalink

코딩테스트 연습 > 연습문제

채점결과Permalink


정확성: 100.0
합계: 100.0 / 100.0

문제 설명Permalink

정수 n을 입력받아 n의 약수를 모두 더한 값을 리턴하는 함수, solution을 완성해주세요.

제한 사항
  • n은 0 이상 3000이하인 정수입니다.
입출력 예
n return
12 28
5 6
입출력 예 설명

입출력 예 #1
12의 약수는 1, 2, 3, 4, 6, 12입니다. 이를 모두 더하면 28입니다.

입출력 예 #2
5의 약수는 1, 5입니다. 이를 모두 더하면 6입니다.

출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges

2. 해결방법 시간복잡도Permalink

  1. 단순 코딩 O(N^2)

3. 문제 해결 및 코드Permalink


def solution(n):
answer = 0
for i in range(1, n + 1):
if n % i == 0:
answer += i
return answer
view raw 12928.py hosted with ❤ by GitHub
  • 주석을 참고하면서 이해를 돕습니다.Permalink

4. 알고리즘 및 해설Permalink

  1. 받은 정수를 i로 나눴을 때 나눠진다면 결과값에 해당 나눠진 값을 추가해주는 방식이다.