문제 설명
양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고
n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 <= n <= 100
입출력 예
n | result |
7 | 16 |
10 | 220 |
입출력 예 설명
입출력 예 #1
- 예제 1번의 n은 7로 홀수입니다. 7 이하의 모든 양의 홀수는 1, 3, 5, 7이고, 이들의 합인 1 + 3 + 5 + 7 = 16을 return 합니다.
입출력 예 #2
- 예제 2번의 n은 10으로 짝수입니다. 10 이하의 모든 양의 짝수는 2, 4, 6, 8, 10이고, 이들의 제곱의 합인 22 + 42 + 62 + 82 + 102 = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.
해결
내 풀이
def solution(n):
answer = 0
if n%2 == 1:
for i in range(n):
if (i+1)%2 == 1:
answer = answer + (i+1)
elif n%2 == 0:
for i in range(n):
if (i+1)%2 == 0:
answer = answer + (i+1)*(i+1)
return answer
다른 풀이
다른 풀이 #1
def solution(n):
if n%2:
return sum(range(1, n+1, 2))
return sum([i*i for i in range(2, n+1, 2)])
다른 풀이 #2
def solution(n):
answer = 0
if n%2:
for i in range(1,n+1,2):
answer += i
else:
for i in range(2,n+1,2):
answer += i**2
return answer
새로 알게 된 점
합산의 경우 sum()을 적극활용할 수 있다...
range(start, stop, step) : start부터 stop-1까지 step 간격으로 생성
'자료구조, 알고리즘' 카테고리의 다른 글
프로그래머스 코딩테스트 연습 [flag에 따라 다른 값 반환하기] (0) | 2025.02.21 |
---|---|
프로그래머스 코딩테스트 연습 [조건 문자열] (0) | 2025.02.21 |
프로그래머스 코딩테스트 연습 [공배수] (0) | 2025.02.21 |
프로그래머스 코딩테스트 연습 [n의 배수] (0) | 2025.02.21 |
프로그래머스 코딩테스트 연습 [두 수의 연산값 비교하기] (0) | 2025.02.21 |