본문 바로가기
코딩테스트/프로그래머스 기초

[코딩테스트 Lv.0] 홀짝에 따라 다른 값 반환하기

by 블루데이제이 2025. 4. 3.
728x90
반응형
문제 설명

양의 정수 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 합니다.

내 풀이
Java
class Solution {
    public int solution(int n) {
        int answer = 0;
        
        if(n % 2 == 0){
            for(int i = 2; i <= n; i += 2){
                answer += (int) Math.pow(i, 2);
            }
        }else{
            for(int i = 1; i <= n; i += 2){
                answer += i;
            }
        }
        
        return answer;
    }
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <math.h>

int solution(int n) {
    int answer = 0;
    int i;
    if(n % 2 == 0){
        for(i = 2; i <= n; i += 2){
            answer += pow(i, 2);
        }
    }else{
        for(i = 1; i <= n; i += 2){
            answer += i;
        }
    }
    
    return answer;
}
Python
def solution(n):
    answer = 0
    
    if n % 2 == 0:
        for i in range(2, n + 1, 2):
            answer += pow(i, 2)
    else:
        for i in range(1, n + 1, 2):
            answer += i
    return answer

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

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

 

728x90
반응형