학이시습

[프로그래머스] 0단계_홀수 vs 짝수 (Java) 본문

Coding test/Programmers

[프로그래머스] 0단계_홀수 vs 짝수 (Java)

dbswndud 2024. 4. 7. 04:08


문제 링크

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

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr


문제 설명

정수 리스트 num_list가 주어집니다. 가장 첫 번째 원소를 1번 원소라고 할 때, 홀수 번째 원소들의 합과 짝수 번째 원소들의 합 중 큰 값을 return 하도록 solution 함수를 완성해 주세요. 두 값이 같을 경우 그 값을 리턴합니다.

 

작성한 코드

class Solution {
    public int solution(int[] num_list) {
        int answer = 0;
        int odd = 0, even = 0;
        
        for (int i = 0; i < num_list.length; i++) {
            if (i % 2 == 0) {
                even += num_list[i];
            } else {
                odd += num_list[i];
            }
        }
        
        if (even > odd) 
            answer = even;
        else 
            answer = odd;
        return answer;
    }
}

 

풀이

  • 홀수 번째 원소들의 합과 짝수 번째 원소들의 합을 저장할 변수를 선언 & 초기화합니다.
  • for문을 num_list의 원소 개수만큼 반복합니다.
    • 만약 i가 짝수라면 even 변수에 i번째의 num_list 값을 더합니다.
    • 짝수가 아니라면 odd 변수에 i번째의 num_list 값을 더합니다.
  • 만약 짝수 번째의 합이 홀수 번째에 합보다 크다면 answer에 even의 값을 저장합니다.
  • 아니라면 answer에 odd의 값을 저장합니다.
  • answer을 리턴해줍니다.

 

실행 결과