문제
두 정수 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
다른 사람 풀이
'Python > 프로그래머스' 카테고리의 다른 글
[프로그래머스 lv.1] 부족한 금액 계산하기 (0) | 2023.09.03 |
---|---|
[프로그래머스 lv.1] 숫자 문자열과 영단어 (0) | 2023.09.03 |
[프로그래머스 lv.1] 로또의 최고 순위와 최저 순위 (0) | 2023.09.02 |
[프로그래머스 lv.1] 음양 더하기 (0) | 2023.09.02 |
[프로그래머스 lv.1] 내적 (0) | 2023.09.01 |