[프로그래머스] 약수의 개수와 덧셈

iamjinseo·2022년 8월 18일
0

문제풀이-Python

목록 보기
52/134

https://school.programmers.co.kr/learn/courses/30/lessons/77884

문제

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

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

시도

1

def solution(left, right):
    answer = 0
    # 약수 개수 구하기
    for i in range(left, right+1):
        res= 0
        for j in range(2, i):
            if i%j == 0:
                res +=1
    # ->홀짝판별
        if res%2==0:
            answer +=i
        else:
            answer -=i
    return answer

결과

2

구글링함

제곱수라면 약수가 홀수라고 한다.

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

결과

profile
일단 뭐라도 해보는 중

0개의 댓글