일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 동영상
- 졸업 작품 소재
- 표준 라이브러리 함수
- 소켓 통신
- 알고리즘
- 산책하기 좋은 곳
- 충남 천안
- c언어
- 원격 제어 프로그램
- 졸업 작품
- 클래스 다이어그램
- 소스 코드
- 언제나 휴일
- 동영상 강의
- 네트워크 프로그래밍
- 프로젝트
- C++
- 유튜브 동영상 강의
- 실습
- 안드로이드 앱 개발
- 파이썬
- 추천
- 실습으로 다지는 c#
- 강의
- 표준 입출력
- Windows Forms
- c#
- 캡슐화
- 무료 동영상 강의
- 언제나휴일
Archives
- Today
- Total
프로그래밍 언어 및 기술 [언제나휴일]
스택을 연결리스트로 구현 본문
1. 유튜브 동영상 강의
2. 개요 및 알고리즘
안녕하세요. 언제나 휴일입니다.
이번에는 스택(STACK)을 연결리스트로 구현하는 소스 코드입니다.
스택은 자료를 한쪽으로 보관하고 꺼내는 LIFO(Last In First Out) 방식의 자료구조입니다. 스택에 자료를 보관하는 연산을 PUSH라 말하고 꺼내는 연산을 POP이라고 말합니다. 그리고 가장 최근에 보관한 위치 정보를 TOP 혹은 스택 포인터라 말합니다.
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 Node //노드 정의
{
int data;
struct Node *next;
}Node;
typedef struct Stack //Stack 구조체 정의
{
Node *top; //맨 앞 노드(가장 최근에 생성한 노드)
}Stack;
void InitStack(Stack *stack);//스택 초기화
int IsEmpty(Stack *stack); //스택이 비었는지 확인
void Push(Stack *stack, int data); //스택에 보관
int Pop(Stack *stack); //스택에서 꺼냄
int main(void)
{
int i;
Stack stack;
InitStack(&stack);//스택 초기화
for (i = 1; i <= 5; i++)//1~5까지 스택에 보관
{
Push(&stack, i);
}
while (!IsEmpty(&stack))//스택이 비어있지 않다면 반복
{
printf("%d ", Pop(&stack));//스택에서 꺼내온 값 출력
}
printf("\n");
return 0;
}
void InitStack(Stack *stack)
{
stack->top = NULL; //스택 초기화에서는 top을 NULL로 설정
}
int IsEmpty(Stack *stack)
{
return stack->top == NULL; //top이 NULL이면 빈 상태
}
void Push(Stack *stack, int data)
{
Node *now = (Node *)malloc(sizeof(Node)); //노드 생성
now->data = data;//데이터 설정
now->next = stack->top;//now의 next링크를 현재 top으로 설정
stack->top = now; //스택의 맨 앞은 now로 설정
}
int Pop(Stack *stack)
{
Node *now;
int re;
if (IsEmpty(stack))
{
return 0;
}
now = stack->top;//now를 top으로 설정
re = now->data;//꺼낼 값은 now의 data로 설정
stack->top = now->next;//top을 now의 next로 설정
free(now);//필요없으니 메모리 해제
return re;
}
'C & C++ > C언어 예제 및 소스' 카테고리의 다른 글
실수를 메모리에 표현하는 방법을 확인하기 위한 공용체 정의하기 (0) | 2025.01.03 |
---|---|
원형 큐 - 버퍼의 모든 공간 사용 (1) | 2024.01.09 |
원형 큐 - 버퍼를 동적으로 생성 (0) | 2024.01.09 |
원형 큐 - 버퍼크기 고정 (0) | 2024.01.09 |
스택 - 버퍼크기 자동 확장 (1) | 2024.01.08 |
스택 - 버퍼 동적 할당 (1) | 2024.01.07 |
스택 - 버퍼 크기 고정 (1) | 2024.01.06 |
힙 정렬(Heap Sort) 알고리즘 (0) | 2024.01.05 |