happy coding

[level 1] 약수의 개수와 덧셈 본문

coding study/programmars

[level 1] 약수의 개수와 덧셈

yeoonii 2024. 6. 25. 00:13

문제 설명

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


제한사항
  • 1 ≤ left  right ≤ 1,000

내 풀이

def solution(left, right):
    ans = 0
    
    for i in range(left, right+1):
        num = 0
        for j in range(1, i+1): 
            if i%j == 0:
                num += 1
                
        if num%2 == 0:
            ans += i
        else:
            ans -= i
            
    return ans

 

다른 풀이

def solution(left, right):
    answer = 0
    for i in range(left,right+1):
        if int(i**0.5)==i**0.5:
            answer -= i
        else:
            answer += i
    return answer
import math

def solution(left, right):
    answer = 0
    for i in range(left, right + 1, 1):
        sqrt = math.sqrt(i)
        if int(sqrt) == sqrt:
            answer -= i
        else:
            answer += i

    return answer
Comments