반응형
문제 설명
정수가 담긴 리스트 num_list가 주어질 때, num_list의 원소 중 짝수와 홀수의 개수를 담은 배열을 return 하도록 solution 함수를 완성해보세요.
제한사항
- 1 ≤ num_list의 길이 ≤ 100
- 0 ≤ num_list의 원소 ≤ 1,000
입출력 예
num_list | result |
[1, 2, 3, 4, 5] | [2, 3] |
[1, 3, 5, 7] | [0, 4] |
소스코드
Solution.c
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// num_list_len은 배열 num_list의 길이입니다.
int* solution(int num_list[], size_t num_list_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int* answer = (int*)malloc(sizeof(int) * 2);
int even = 0, odd = 0;
int i;
for(i = 0; i<num_list_len; i++){
if(num_list[i] % 2 == 0)
even++;
else if(num_list[i] % 2 != 0)
odd++;
}
answer[0] = even;
answer[1] = odd;
return answer;
}
풀이
even은 짝수의 개수 odd는 홀수의 개수로 사용할 변수를 선언해준다. 다음 for문을 이용하여 배열을 처음부터 확인하고, if문을 이용하여 2로 나누었을때 나머지가 0이면 짝수 0이 아니면 홀수라고 설정해 준다. 그리고 해당 조건에 맞는 변수의 크기를 올려준다. 그리고 answer에 짝수와 홀수개수를 가지고 있는 even과 odd를 차례 차례 넣어주면된다.
출처: 프로그래머스 코딩 테스트 연습, https://programmers.co.kr/learn/challenges
코딩테스트 연습 | 프로그래머스 스쿨
개발자 취업의 필수 관문 코딩테스트를 철저하게 연습하고 대비할 수 있는 문제를 총망라! 프로그래머스에서 선발한 문제로 유형을 파악하고 실력을 업그레이드해 보세요!
school.programmers.co.kr