Notice
Recent Posts
Recent Comments
Link
«   2024/07   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
Tags
more
Archives
Today
Total
관리 메뉴

김찬양의 개발일지

25일차. 약수의 개수와 덧셈 본문

코딩테스트/Programmers Level 1

25일차. 약수의 개수와 덧셈

자유로운영혼이다냥 2023. 12. 19. 22:11

링크

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 


 

문제


 

정답

def solution(left, right):
    answer = 0
    for i in range(left, right+1):
        root = i**(1/2)
        if root==int(root):
            answer -= i
        else:
            answer += i
    return answer

 

풀이과정

약수를 구하는 과정을 생각해보면, 약수는 두 수를 곱해서 어떤 수가 되므로 반드시 짝지어진다. 다만 짝지어진 두 수가 같은 수일경우엔 약수의 갯수가 홀수개가 된다. 그러므로 제곱수는 약수의 갯수가 홀수이고, 약수의 갯수가 홀수이려면 제곱수여야한다.