Python/프로그래머스

[프로그래머스 lv.1] 약수의 개수와 덧셈

묘걍 2023. 9. 2. 12:46

문제

두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.


제한사항

  • 1 ≤ left  right ≤ 1,000

 

내가 생각한 풀이 방법

약수 구하는 함수 정의

range(left, right+1)까지 for문을 돌면서

약수 함수 결과 % 2 == 0이면 sum_list.append(i)

아니면 sum_list.append(i*(-1))

 

코드로 구현

1차 시도

def devided(num):
    devisor = []
    for i in range(1, num+1):
        if num % i == 0:
            devisor.append(i)
    return devisor

def solution(left, right):
    answer = 0
    sum_list = []
    for i in range(left, right+1):
        if devided(i) % 2 == 0:
            sum_list.append(i)
        else:
            sum_list.append(i*(-1))
    answer = sum(sum_list)
    return answer

- 개수 반환을 제대로 구현하지 않음

 

2차 시도

def devided(num):
    devisor = []
    for i in range(1, num+1):
        if num % i == 0:
            devisor.append(i)
    return len(devisor)

def solution(left, right):
    answer = 0
    sum_list = []
    for i in range(left, right+1):
        if devided(i) % 2 == 0:
            sum_list.append(i)
        else:
            sum_list.append(i*(-1))
    answer = sum(sum_list)
    return answer

 

다른 사람 풀이