반응형
A형 필수 알고리즘을 체계적으로 배우고 싶다면? (인프런 바로가기)
스택 기본 구현 문제이다.
push, pop, size, empty, top을 구현해야 한다.
명령의 수가 최대 10000이므로 10000보다 큰 배열을 잡고, index 하나만 추가하면 stack이 완성된다.
즉 push할 때는 index = stack pointer = sp를 증가 시키고, pop할 때는 sp를 감소시킨다.
배열에 값을 넣고, sp를 증가시키면 들어오는 순서대로 값을 저장할 수 있다.
stack[sp] = input, sp++;
→ stack[sp++] = input;
값을 입력하고 sp를 증가시켰기 때문에 바로 이전 값은 sp - 1에 있다.
output = stack[sp - 1], sp--;
→ output = stack[--sp];
이렇게 구현하면 sp = stack의 size, sp - 1은 top이 되고, sp가 0인지 확인하면 empty인지도 확인 가능하다.
크기를 넉넉하게 잡았으니, push를 check할 필요는 없지만,
빈 stack에 pop을 하면 sp가 -1이 되므로,
if(sp)를 추가해서 보완하면 된다.
#include <stdio.h>
int mystrcmp(const char *a, const char *b)
{
while (*a && *a == *b) ++a, ++b;
return *a - *b;
}
int main()
{
int in, N;
int stack[10000 + 500] = { 0 };
int sp = 0; /* stack pointer */
scanf("%d", &N);
for (int i = 0; i < N; i++)
{
char input[10];
scanf("%s", input);
if (mystrcmp(input, "push") == 0)
{
scanf("%d", &in);
stack[sp++] = in;
}
else if (mystrcmp(input, "pop") == 0)
{
if (sp) printf("%d\n", stack[--sp]);
else printf("-1\n");
}
else if (mystrcmp(input, "size") == 0) printf("%d\n", sp);
else if (mystrcmp(input, "empty") == 0) printf("%d\n", sp ? 0 : 1);
else if (mystrcmp(input, "top") == 0) printf("%d\n", sp ? stack[sp - 1] : -1);
}
return 0;
}
반응형
'알고리즘 > BAEKJOON' 카테고리의 다른 글
BOJ 14501, 15486 : 퇴사, 퇴사 2 (0) | 2021.02.15 |
---|---|
BOJ 10866 : 덱 (0) | 2021.02.08 |
BOJ 10845, 18258 : 큐, 큐2 (0) | 2021.02.07 |
BOJ 9012 : 괄호 (0) | 2021.02.07 |
BOJ 10773 : 제로 (0) | 2021.02.06 |
댓글