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
다른 사람 풀이