문제
아무 원소도 들어있지 않은 빈 배열 X가 있습니다. 길이가 같은 정수 배열 arr과 boolean 배열 flag가 매개변수로 주어질 때, flag를 차례대로 순회하며 flag[i]가 true라면 X의 뒤에 arr[i]를 arr[i] × 2 번 추가하고, flag[i]가 false라면 X에서 마지막 arr[i]개의 원소를 제거한 뒤 X를 return 하는 solution 함수를 작성해 주세요.
솔루션
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
// arr_len은 배열 arr의 길이입니다.
// flag_len은 배열 flag의 길이입니다.
int* solution(int arr[], size_t arr_len, bool flag[], size_t flag_len) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
int* answer = (int*)malloc(100 * 100 * sizeof(int));
int n = 0;
for(int i = 0; i < arr_len; i++){
if(flag[i])
{
for(int j = 0; j < arr[i] * 2; j++)
answer[n++] = arr[i];
}
else
{
for(int j = 0; j < arr[i]; j++)
n--;
}
}
return answer;
}
https://school.programmers.co.kr/learn/courses/30/lessons/181860
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
'프로그래머스코딩테스트연습풀이 > C언어' 카테고리의 다른 글
[프로그래머스/C언어] 문자열이 몇 번 등장하는지 세기 (0) | 2023.08.15 |
---|---|
[프로그래머스/C언어] 1로 만들기 (0) | 2023.08.15 |
[프로그래머스/C언어] k의 개수 (0) | 2023.08.15 |
[프로그래머스/C언어] 가까운 수 (0) | 2023.08.14 |
[프로그래머스/C언어] 이차원 배열 대각선 순회하기 (0) | 2023.08.14 |