반응형
문제 설명
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ left ≤ right ≤ 1,000
입출력 예
left | right | return |
13 | 17 | 43 |
24 | 27 | 52 |
solution.py
def solution(left, right):
# 약수 갯수 Count
answer = []
for n in range(left, right+1):
factor = 0
for x in range(1, n+1):
if n % x == 0:
factor += 1
if factor % 2 == 1: answer.append(-1 * n)
else : answer.append(n)
return sum(answer)
반응형
'Programmers (코딩 테스트 연습)' 카테고리의 다른 글
문자열 내 마음대로 정렬하기(연습문제, Level 1) (0) | 2022.06.02 |
---|---|
최소직사각형 (위클리 챌린지, Level 1) (0) | 2022.06.02 |
나머지가 1이 되는 수 찾기 (월간 코드 챌린지 시즌3, Level 1) (0) | 2022.03.26 |
음양 더하기 (월간 코드 챌린지 시즌2, Level 1) (0) | 2022.03.26 |
최대공약수와 최소공배수 (연습문제, Level 1) (0) | 2022.03.26 |
댓글