일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 언제나 휴일
- 소켓 통신
- Windows Forms
- 소스 코드
- 무료 동영상 강의
- 실습으로 다지는 c#
- 클래스 다이어그램
- 캡슐화
- 표준 라이브러리 함수
- 충남 천안
- C++
- 파이썬
- 동영상 강의
- 유튜브 동영상 강의
- 네트워크 프로그래밍
- 안드로이드 앱 개발
- 추천
- 프로젝트
- c#
- 강의
- c언어
- 실습
- 알고리즘
- 졸업 작품
- 졸업 작품 소재
- 산책하기 좋은 곳
- 언제나휴일
- 원격 제어 프로그램
- 표준 입출력
- 동영상
Archives
- Today
- Total
프로그래밍 언어 및 기술 [언제나휴일]
스택 - 버퍼 동적 할당 본문
1. 스택
이번에 작성할 코드는 버퍼를 동적으로 할당받는 스택(STACK)입니다.
스택은 자료를 한쪽으로 보관하고 꺼내는 LIFO(Last In First Out) 방식의 자료구조입니다. 스택에 자료를 보관하는 연산을 PUSH라 말하고 꺼내는 연산을 POP이라고 말합니다. 그리고 가장 최근에 보관한 위치 정보를 TOP 혹은 스택 포인터라 말합니다.
2. 알고리즘
Push 연산
IF Top> MAX Then (꽉차면)
Overflow (버퍼오버플로우)
Else (꽉차지않을때)
Top = Top +1 (Top 위치를 1 증가)
Buffer[Top] = data (버퍼의 Top 위치에 data 보관)
Pop 연산
IF Top=-1 Then (비었으면)
Underflow (버퍼언더플로우)
Else
data = Buffer[Top] (버퍼의 Top 위치의값을데이터에설정)
Top = Top -1 (Top 위치를 1 감소)
3. 소스 코드
//스택 - 버퍼를 동적 할당, 정수 형식 보관
#include <stdio.h>
#include <stdlib.h>
typedef struct Stack //Stack 구조체 정의
{
int *buf;//저장소
int ssize;//저장소 크기
int top; //가장 최근에 보관한 인덱스
}Stack;
void InitStack(Stack *stack, int ssize);//스택 초기화
int IsFull(Stack *stack); //스택이 꽉 찼는지 확인
int IsEmpty(Stack *stack); //스택이 비었는지 확인
void Push(Stack *stack, int data); //스택에 보관
int Pop(Stack *stack); //스택에서 꺼냄
void DisposeStack(Stack *stack);//스택 해제화
int main(void)
{
int i;
Stack stack;
InitStack(&stack, 10);//스택 초기화
for (i = 1; i <= 5; i++)//1~5까지 스택에 보관
{
Push(&stack, i);
}
while (!IsEmpty(&stack))//스택이 비어있지 않다면 반복
{
printf("%d ", Pop(&stack));//스택에서 꺼내온 값 출력
}
printf("\n");
DisposeStack(&stack);//스택 해제화
return 0;
}
void InitStack(Stack *stack, int ssize)
{
stack->buf = (int *)malloc(sizeof(int)*ssize);
stack->ssize = ssize;
stack->top = -1; //스택 초기화에서는 top을 -1로 설정
}
int IsFull(Stack *stack)
{
return (stack->top + 1) == stack->ssize;//top+1 이 스택 크기와 같으면 꽉 찬 상태
}
int IsEmpty(Stack *stack)
{
return stack->top == -1; //top이 -1이면 빈 상태
}
void Push(Stack *stack, int data)
{
if (IsFull(stack))
{
printf("스택이 꽉 찼음\n");
return;
}
stack->top++; //top을 1 증가
stack->buf[stack->top] = data; //데이터 보관
}
int Pop(Stack *stack)
{
int re = 0;
if (IsEmpty(stack))
{
printf("스택이 비었음\n");
return re;
}
re = stack->buf[stack->top];//top 인덱스에 보관한 값을 re에 설정
stack->top--;//top을 1 감소
return re;
}
void DisposeStack(Stack *stack)
{
free(stack->buf);
}
'C & C++ > C언어 예제 및 소스' 카테고리의 다른 글
원형 큐 - 버퍼를 동적으로 생성 (0) | 2024.01.09 |
---|---|
원형 큐 - 버퍼크기 고정 (0) | 2024.01.09 |
스택을 연결리스트로 구현 (0) | 2024.01.09 |
스택 - 버퍼크기 자동 확장 (1) | 2024.01.08 |
스택 - 버퍼 크기 고정 (1) | 2024.01.06 |
힙 정렬(Heap Sort) 알고리즘 (0) | 2024.01.05 |
병합 정렬(합병 정렬, Merge Sort) 알고리즘 (1) | 2024.01.04 |
퀵 정렬 (Quick Sort) (1) | 2024.01.03 |