[문제]
두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.
[풀이]
이 문제는 어떤 정수의 약수의 개수가 홀수인지 짝수인지 판별하는 방법만 알면 효율적으로 풀 수 있다.
약수는 쌍으로 존재하는데, 제곱수의 경우 그 쌍이 자기 자신이다. 즉, 제곱수의 약수의 개수는 홀수개이다.
이를 이용해 문제를 풀어보자
def solution(left, right):
return sum(-n if (n**0.5).is_integer() else n
for n in range(left, right+1))
'코딩 테스트 > Python' 카테고리의 다른 글
행렬의 덧셈 (0) | 2024.12.15 |
---|---|
부족한 금액 계산하기 (0) | 2024.12.15 |
음양 더하기 (0) | 2024.12.15 |
두 정수 사이의 합 (0) | 2024.12.15 |
약수의 합 (0) | 2024.12.15 |