Search
Duplicate

약수의 개수와 덧셈

문제 설명 및 제한사항

문제 설명

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

제한사항

1 ≤ left ≤ right ≤ 1,000

아이디어 및 해결 방법

코드

def num_divisor(n): return len([x for x in range(1, n+1) if n % x == 0]) def solution(left, right): s = 0 for i in range(left, right+1): if num_divisor(i) % 2 == 0: s += i else: s -= i return s
Python
복사

출처

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