문제 설명
스택 두개를 이용해 Queue 자료구조를 만들었을 때, Queue 자료 구조의 pop(또는 dequeue) 함수를 구현하려합니다. Queue란 먼저 삽입한 데이터를 먼저 빼내는 자료구조를 뜻합니다. pop 함수를 만들기 위해 다음과 같이 프로그램 구조를 작성했습니다.
1. 스택2가 비었다면 스택1에 아무것도 남지 않을때까지 스택1을 pop한 값을 스택2에 push 한다.
2. 스택2를 pop한 값을 리턴한다.
배열 stack1과 정수 stack1_idx, 배열 stack2과 정수 stack2_idx가 solution 함수의 매개변수로 주어집니다. 이때, stack1_idx는 stack1을 스택으로 이용했을 때 stack1의 top의 index를 의미하며, stack2_idx는 stack2를 스택으로 이용했을 때 stack2의 top의 index를 의미합니다.
두 배열을 스택으로 이용해 Queue 자료 구조의 pop 함수를 구현하려합니다. 위 구조를 참고하여 코드가 올바르게 동작할 수 있도록 빈칸에 주어진 func_a, func_b, func_c 함수와 매개변수를 알맞게 채워주세요.
※ 배열 index가 0인 부분을 스택의 bottom으로 생각합니다.
매개변수 설명
배열 stack1과 정수 stack1_idx, 배열 stack2과 정수 stack2_idx가 solution 함수의 매개변수로 주어집니다. 이때, stack1_idx는 stack1을 스택으로 이용했을 때 stack1의 top의 index를 의미하며, stack2_idx는 stack2를 스택으로 이용했을 때 stack2의 top의 index를 의미합니다.
- stack1과 stack2는 길이가 0 이상 10 이하입니다.
- stack1과 stack2의 길이가 모두 0인 경우는 주어지지 않습니다.
- stack1과 stack2의 원소는 100 이하인 정수입니다.
- stack1_idx는 -1 이상 stack1의 길이 미만인 정수입니다.
- stack2_idx는 -1 이상 stack2의 길이 미만인 정수입니다.
return 값 설명
stack1과 stack2로 구현한 큐를 pop(또는 dequeue)한 값을 return 해주세요.
- 스택이 넘치는 일은 발생하지 않는다고 가정합니다.
예제
stack1 | stack1_idx | stack2 | stack2_idx | result |
---|---|---|---|---|
[1,2,0,0,0,0,0,0,0,0] | 1 | [3,4,0,0,0,0,0,0,0,0] | 1 | 4 |
[1,2,3,0,0,0,0,0,0,0] | 2 | [0,0,0,0,0,0,0,0,0,0] | -1 | 1 |
예제 설명
예제 #1
stack2가 비지 않았으므로 stack2를 pop 한 결과인 4를 리턴합니다.
예제 #2
- stack2가 비었으므로 stack1의 원소를 전부 pop해 stack2로 넣습니다. 이 결과 stack2는 [3,2,1,0,0,0,0,0,0,0]이 됩니다.
- stack2를 pop한 결과인 1을 리턴합니다.
- 빈칸 채우기는 이미 완성된 코드 중 빈칸에 알맞은 코드를 입력하는 문제 타입입니다.
- 빈칸을 제외한 기본 코드는 수정할 수 없습니다.
- 빈칸을 채우지 않을 경우, 실행 결과에 에러 메시지가 표시됩니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
int func_a(int stack[], int *stack_idx);
void func_b(int stack1[], int *stack1_idx, int stack2[], int *stack2_idx);
bool func_c(int stack_idx);
int func_a(int stack[], int *stack_idx) {
int item = stack[*stack_idx];
*stack_idx = *stack_idx - 1;
return item;
}
void func_b(int stack1[], int *stack1_idx, int stack2[], int *stack2_idx) {
while(!func_()) {
int item = func_();
*stack2_idx = *stack2_idx + 1;
stack2[*stack2_idx] = item;
}
}
bool func_c(int stack_idx){
return (stack_idx == -1);
}
int solution(int stack1[], int stack1_idx, int stack2[], int stack2_idx) {
if(func_()){
func_();
}
int answer = func_();
return answer;
}
// 아래는 테스트케이스 출력을 해보기 위한 main 함수입니다.
int main() {
int stack1_1[] = {1,2,0,0,0,0,0,0,0,0};
int stack1_1len = 1;
int stack2_1[] = {3,4,0,0,0,0,0,0,0,0};
int stack2_1len = 1;
int ret1 = solution(stack1_1, stack1_1len, stack2_1, stack2_1len);
// [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
printf("solution 함수의 반환 값은 %d 입니다.\n", ret1);
int stack1_2[] = {1,2,3,0,0,0,0,0,0,0};
int stack1_2len = 2;
int stack2_2[] = {0,0,0,0,0,0,0,0,0,0};
int stack2_2len = -1;
int ret2 = solution(stack1_2, stack1_2len, stack2_2, stack2_2len);
// [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
printf("solution 함수의 반환 값은 %d 입니다.\n", ret2);
}