홀짝에 따라 다른 값 반환하기
문제설명
양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고 n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.
제한사항
- 1 ≤ n ≤ 100
입출력 예
입출력 예 설명
입출력 예 #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 합니다.
작성코드
#include <string>
#include <vector>
using namespace std;
int solution(int n) {
int answer = 0;
if (n % 2 != 0) // n이 홀수가 아닐 경우에
{
// n 이하의 홀수인 모든 양의 정수의 합을 return
for(int i=1; i<=n; i+=2)
answer += i; // 1,3,5,7 ....
}
else // 짝수일 경우
{
// 모든 양의 정수의 제곱의 합을 return
for(int i=2; i<=n; i+=2)
answer += i*i; // 0,2,4 ...
}
return answer;
}
문제 URL
https://school.programmers.co.kr/learn/courses/30/lessons/181935
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr