반응형
더 많은 배수 구하기
문제 설명
자연수가 들어있는 배열에 3의 배수와 5의 배수 중 어떤 수가 더 많은지 알아보려 합니다.
1. 3의 배수의 개수를 셉니다.
2. 5의 배수의 개수를 셉니다.
3. 3의 배수와 5의 배수의 개수를 비교 후 다음을 수행합니다.
3-1. 3의 배수가 더 많다면 "three"를 return 합니다.
3-2. 5의 배수가 더 많다면 "five"를 return 합니다.
3-3. 3의 배수와 5의 배수의 개수가 같다면 "same"를 return 합니다.
위 구조를 참고하여 코드가 올바르게 동작할 수 있도록 빈칸에 주어진 func_a, func_b, func_c 함수와 매개변수를 알맞게 채워주세요.
예시
arr | arr_len | reutrn |
{2, 3, 6, 9, 12, 15, 10, 20, 22, 25} | 10 | "three" |
코드 해석 및 전체 코드
func_a 함수는 5의 배수를 구하는 함수이다.
2 | 3 | 6 | 9 | 12 | 15 | 10 | 20 | 22 | 25 |
X | X | X | X | X | O | O | O | X | O |
count = 4
func_b 함수는 3의 배수의 개수와 5의 배수의 개수를 비교하여 최종 return값을 주는 함수이다.
3의 배수 | 5의 배수 | return |
5 | 4 | three |
func_c 함수는 3의 배수를 구하는 함수이다.
2 | 3 | 6 | 9 | 12 | 15 | 10 | 20 | 22 | 25 |
X | O | O | O | O | O | X | X | X | X |
count = 5
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
int func_a(int arr[], int arr_len) {
int count = 0;
for (int i = 0; i < arr_len; ++i)
if (arr[i] % 5 == 0)
count += 1;
return count;
}
char* func_b(int three, int five) {
if (three > five)
return "three";
else if (three < five)
return "five";
else
return "same";
}
int func_c(int arr[], int arr_len) {
int count = 0;
for (int i = 0; i < arr_len; ++i)
if (arr[i] % 3 == 0)
count += 1;
return count;
}
char* solution(int arr[], int arr_len) {
int count_three = func_c(arr, arr_len);
int count_five = func_a(arr, arr_len);
char* answer = func_b(count_three, count_five);
return answer;
}
int main() {
int arr[10] = { 2, 3, 6, 9, 12, 15, 10, 20, 22, 25 };
int arr_len = 10;
char* ret = solution(arr, arr_len);
printf("The return value of solution function is %s \n", ret);
}
반응형
'코딩 테스트 > [c언어] cos pro 2급 기출문제' 카테고리의 다른 글
[No.14] 5글자 이상인 단어 배열하기 / cos pro 2급 c언어 기출 문제 (0) | 2021.05.09 |
---|---|
[No.13] 짝수들의 제곱의 합 구하기 / cos pro 2급 c언어 기출 문제 (0) | 2021.05.09 |
[No.11] 최대한 많은 쌍의 장갑 개수 구하기 / cos pro 2급 c언어 기출 문제 (0) | 2021.05.08 |
[No.10] 평균 이하의 개수 구하기 / cos pro 2급 c언어 기출 문제 (0) | 2021.05.08 |
[No.9] 중복 문자 삭제하기 / cos pro 2급 c언어 기출 문제 (0) | 2021.05.07 |
댓글