happy coding
[level 1] 약수의 개수와 덧셈 본문
문제 설명
두 정수 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
'coding study > programmars' 카테고리의 다른 글
[level 1] 부족한 금액 계산하기 (0) | 2024.06.26 |
---|---|
[level 1] 문자열 내림차순으로 배치하기 (0) | 2024.06.26 |
[level 1] 내적 (0) | 2024.06.24 |
[level 1] 수박수박수박수박수박수? (0) | 2024.06.24 |
[level 1] 가운데 글자 가져오기 (0) | 2024.06.23 |
Comments