코딩테스트/프로그래머스

[프로그래머스] 홀짝에 따라 다른 값 반환하기

블로그 주인장 2023. 8. 10.

목차


    📢 문제 출처


    ⏰ 문제 설명

    • 양의 정수 n이 매개변수로 주어질 때, n이 홀수라면 n 이하의 홀수인 모든 양의 정수의 합을 return 하고 
    •  n이 짝수라면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 return 하는 solution 함수를 작성해 주세요.

    ⏰ 입출력 예시

    • 입출력 예 #1
    • (1) 예제 1번의 n은 7로 홀수입니다. 7 이하의 모든 양의 홀수는 1, 3, 5, 7이고
    • (2) 이들의 합인 1 + 3 + 5 + 7 = 16을 return 합니다.
    • 입출력 예 #2
    • (1) 예제 2번의 n은 10으로 짝수입니다. 10 이하의 모든 양의 짝수는 2, 4, 6, 8, 10이고
    • (2) 이들의 제곱의 합인 22 + 42 + 62 + 82 + 102 = 4 + 16 + 36 + 64 + 100 = 220을 return 합니다.

    ⏰ 풀이

    class Solution {
        public int solution(int n) {
            int answer = 0;
    
            if (n%2==0) //짝수
            {
                for (int i = 0; i <= n; i++) {
                    if(i%2==0){
                        answer += (int)Math.pow(i,2);
                    }
                }
            }
            else    //홀수
            {
                for (int i = 0; i <= n; i++) {
                    if(i%2 ==1){
                        answer +=i;
                    }
                }
            }
    
            return answer;
        }
    }
    • n의 값이 짝수인 경우에는 제곱수로 계산, 홀수인 경우에는 홀수 합의 계산이다.
    • 1차로, n의 값의 짝수인지, 홀수인지 조건식을 구해야한다.
    • 구한 이후, n의 값 이하의 합을 해야하기 때문에 for문을 사용한다.
    • 짝수의 경우, 짝수일 때만 제곱수를 더해야하기 때문에, for문에서 짝수의 경우를 추출하고,
    • Math.pow(a,b) 함수를 사용하여 제곱수를 구한다. a = 값, b= 제곱수이다.  ex) a=2, b=3 이면 2의 3승이 된다.
    • 홀수의 경우, 홀수일 때만 값을 더해야하기 때문에 for문에서 홀수의 조건식에서 값을 합해준다.

     

    반응형

    댓글