2. 스택의 구현

2023. 3. 7. 14:34·다양한 글들/자료구조와 알고리즘

https://blogshine.tistory.com/36

 

[자료구조] C++로 쉽게 풀어쓴 자료구조 : 6장, List

내돈내고 내가 공부한것을 올리며, 중요한 단원은 저 자신도 곱씹어 볼겸 가겹게 포스팅 하겠습니다. 1) 6장. 리스트 앞에서 배운 스택, 큐, 덱과 같이 리스트 또한 선형 자료구조 이다. 선형이란

blogshine.tistory.com

배열은 순차적인 메모리 공간에 할당된다고 해서 순차적 표현(sequential representation)라고도 한다.


배열을 이용한 스택의 표현
  • 스택을 가장 간단하게 구현할 수 있는 방법은 배열을 이용하는 것이다.
  • 정수를 저장할 스택을 만들려면 정수의 1차원 배열이 있어야 하고 이를 data[MAX_STACK_SIZE]라고 부른다.
  • 이 배열을 이용하여 스택의 요소들을 저장하게 된다
  • 스택에서는 삽입과 삭제 연산을 위한 변수인 top이 필요한데 이 변수는 스택에서 가장 최근에 입력되었던 자료의 위치를 가리킨다.
  • 상수인 MAX_STACK_SIZE는 스택에 저장할 수 있는 최대 요소의 개수를 나타낸다.

  • 스택이 처음 생성되면 top은 -1로 초기화된다.
  • 새로운 항목이 스택에 push()로 추가되면 top+1 위치인 data[0]에 저장된다.

공백 상태와 포화 상태 검사

top = -1

:스택에는 항목이 하나도 없는 공백 상태

 

top = MAX_STACK_SIZE -1

: 포화 상태


삽입 연산

  • 새로운 항목 C를 스택에 삽입하면 C는 스택의 맨 위에 올라가고 top도 하나 증가시켜야 한다.
  • 스택이 가득 차면 더 이상 삽입이 불가능하므로 push 연산에서는 먼저 isFull 연산을 이용하여 이를 검사한다.
  • 스택이 가득 차 있다면 에러 메지만 출력한다.
  • 그렇지 않으면 top을 먼저 하나 증가시킨 후 이 위치에 요소 x를 스택에 삽입한다
  • 삽입 연산 후 top은 가장 최근에 삽입된 요소의 위치를 가리켜야 한다.

삭제 연산

  • pop 연산은 top이 가리키는 요소를 스택에서 꺼내서 반환하는 연산이다.
  • 이 경우에도 isEmpty 연산을 이용하여 먼저 스택의 공백 여부를 검사해야 하는데, 공백이면 에러 메세지만 출력한다.
  • 비어 있지 않으면 top이 가리키는 값을 반환하고 top을 하나 감소시킨다.

배열을 이용한 스택의 구현 C언어
  • 1차원 배열과 top 변수를 모두 전역 변수로 구현한다.
  • 전역 변수로 구현되기 때문에 배열이나 top 변수를 함수의 매개 변수로 전달할 필요가 없다
  • 스택에 저장되는 데이터의 타입은 typedef을 이용하여 element로 정의되었다.
  • 현재는 정수형으로 정의되어 있다.
  • push 연산은 top을 먼저 증가시킨 다음, 증가된 위치에 데이터를 저장한다. pop 연산은 먼저 top이 가리키는 위치에서 데이터를 꺼내온 다음, top을 하나 감소한다

 

#include <stdio.h>
#include <stdlib.h>

#define MAX_STACK_SIZE 100	// 스택의 최대 크기
typedef int element;		// 데이터의 자료형
element  stack[MAX_STACK_SIZE]; // 1차원 배열
int  top = -1;

// 공백 상태 검출 함수
int is_empty()
{
	return (top == -1);
}
// 포화 상태 검출 함수
int is_full()
{
	return (top == (MAX_STACK_SIZE - 1));
}
// 삽입 함수
void push(element item)
{
	if (is_full()) {
		fprintf(stderr, "스택 포화 에러\n");
		return;
	}
	else stack[++top] = item;
}
// 삭제 함수
element pop()
{
	if (is_empty()) {
		fprintf(stderr, "스택 공백 에러\n");
		exit(1);
	}
	else return stack[top--];
}
// 피크 함수
element peek()
{
	if (is_empty()) {
		fprintf(stderr, "스택 공백 에러\n");
		exit(1);
	}
	else return stack[top];
}

int main(void)
{
	push(1);
	push(2);
	push(3);
	printf("%d\n", pop());
	printf("%d\n", pop());
	printf("%d\n", pop());
	return 0;
}

배열을 이용한 스택의 구현 C++

배열을 이용한 스택을 C++로 구현하려면 UML 다이어그램을 이용하여 스택을 구체적으로 설계한다

[클래스 다이어그램의 구성]

  • 1 번째 박스는 클래스의 이름을 나타낸다
  • 2 번째 박스는 데이터 멤버를 나타낸다 => 스택의 top 변수와 항목을 저장할 배열을 데이터 멤버로 갖는다. 이들은 모두 '-'로 나타내었으므로 private의 접근 권한을 갖는다.
  • 3 번째 박스는 멤버 함수 (method)들을 나타낸다 => 생성자와 함께 앞에서 설명한 연산들을 이름과 매개변수, 반환형을 나타내고 있다.

 

ArrayStack.h

#pragma once
#include <iostream>
#include <cstdio>
#include <cstdlib>

using namespace std;
const int MAX_STACK_SIZE = 20;

inline void error(const char* message) {
	printf("%s\n", message);
	exit(1);
}

template <typename T>
class ArrayStack
{
	int top;
	T data[MAX_STACK_SIZE];
public:
	ArrayStack() { top = -1; } // stack constructor
	~ArrayStack() {}
	bool isEmpty() { return top == -1; }
	bool isFull() { return top == MAX_STACK_SIZE - 1; }
	void push(const T& e);
	T pop();
	T peek();
	void display();
};

template <typename T>
void ArrayStack<T>::push(const T& e)
{
	if (isFull()) error("스택이 가득참.");
	data[++top] = e;
}

template <typename T>
T ArrayStack<T>::pop()
{
	if (isEmpty()) error("스택이 비어있습니다.");
	return data[top--];
}

template <typename T>
T ArrayStack<T>::peek()
{
	if (isEmpty()) error("스택이 비어있습니다.");
	return data[top];
}

template <typename T>
void ArrayStack<T>::display()
{
	printf("[스택에 들어있는 원소의 수 = %2d] : ", top + 1);
	for (int i = 0; i <= top; i++)
		cout << "<" << data[i] << "> ";
	printf("\n");
}

 

main.cpp

#include "ArrayStack.h"

int main()
{
	ArrayStack<float> stack;
	for (float i = 0.5; i < 10; i++) {
		stack.push(i);
	}

	stack.display();
	stack.pop();
	stack.pop();
	stack.display();

	cout << "peek: " << stack.peek();
               
	return 0;
}

복잡한 구조의 항목에 대한 스택의 구현
  • 만약 스택에 저장되어야 하는 값이 정수나 문자가 아니고 더 복잡한 구조를 갖는 항목이면 어떻게 해야 할까?
  • 예를 들어, 학생에 대한 정보라면 학번, 이름, 학과 등의 정보가 포함되어야 할 것이다.
  • 프로그램 3.1에서는 int를 저장하는 스택을 구현하였다.
  • 만약 학생 정보를 저장하는 스택을 구현하려면 먼저 스택에 저장할 요소를 위한 새로운 클래스가 필요하다.
  • 그림 3.11은 학생의 정보를 나타내는 Student 클래스를 만들고, Student 객체들을 관리하는 학생 스택을 만드는 예를 클래스 다이어그램으로 보여준다.
  • 이제 스택의 요소에는 한 학생의 학번(int), 이름(문자열, char[])및 학과(문자열) 정보가 저장된다.


연결 리스트를 이용한 스택의 표현
  • 배열을 이용하여 구현한 스택은 구현이 간편하지만 약점이  하나 있다.
  • 스택의 크기가 제한된다는 것이다.
  • 앞에서 구현한 스택의 크기는 MAX_STACK_SIZE에 제한된다

하지만 연결 리스트를 사용하면 이를 해결할 수 있다

저작자표시

'다양한 글들 > 자료구조와 알고리즘' 카테고리의 다른 글

1. 큐 ADT  (0) 2023.03.07
3. 스택의 응용  (0) 2023.03.07
1. 스택 ADT  (0) 2023.03.07
3. 연결 리스트로 구현된 리스트  (0) 2023.03.07
2. 연결 리스트  (0) 2023.03.07
'다양한 글들/자료구조와 알고리즘' 카테고리의 다른 글
  • 1. 큐 ADT
  • 3. 스택의 응용
  • 1. 스택 ADT
  • 3. 연결 리스트로 구현된 리스트
smile blog
smile blog
건국대 첨단바이오공학부 & 컴퓨터공학부 BT & IT 기술로 희망을 꿈 꿉니당
  • smile blog
    스마일 블로그
    smile blog
  • 전체
    오늘
    어제
    • 분류 전체보기 (816) N
      • 일상 생각들 (2)
      • 학과에 대해 (4) N
        • 첨단바이오공학부 (4) N
        • 컴퓨터공학부 (0)
      • -------- 프로젝트 -------- (0)
      • [DS] 토이 프로젝트 (1)
      • [Web, Game, XR] 토이 프로젝트 (11)
      • 경진대회 (1)
      • -------- 진로 -------- (0)
      • 생물정보학자 (18)
        • 데이터 과학이란? (0)
        • 되는 방법 (8)
        • 책 추천 (2)
        • 인강 (1)
        • 대학 (2)
        • 회사 (1)
        • 학원 (2)
        • 학회 (2)
      • 디지털 헬스케어 (72)
        • 방법 (8)
        • 생각들 (10)
        • 공부법 (4)
        • 책 추천 (2)
        • 학원 (2)
        • 참고 (2)
        • 대학 (3)
        • 회사 (3)
        • 인강 (2)
        • 게임 엔진들 (1)
        • 게임 프로그래머 개론 (2)
        • 게임 프로그래머 취업 전략 가이드 (7)
        • 취업 서류 (1)
        • 애정하는 게임들 (4)
        • XR 테크니컬 아티스트 (9)
        • 영화, 애니메이션 테크니컬 디렉터 (12)
      • -------- 기초 학문 -------- (0)
      • 생명과학 이야기 (2)
        • 대학 강의 (2)
      • 화학 이야기 (0)
      • 컴퓨터과학 이야기 (0)
      • 통계학 이야기 (0)
      • 수학 이야기 (1)
        • 공학 수학 (1)
      • 영어 이야기 (1)
      • 심리학 이야기 (7)
        • 현대인과 정신건강 (7)
      • -------- 컴퓨터 언어 -------- (0)
      • Python (3)
        • 나도코딩의 파이썬 입문 (1)
        • 파이썬 관련 정보 (1)
      • SQL (0)
      • C 언어 (32)
        • 혼자 공부하는 C언어 요약 (1)
        • [책 정리] 혼자 공부하는 C언어 (31)
      • C++ (33)
        • 명품 C++ 프로그래밍 요약 (1)
        • [책 정리] 명품 C++ 프로그래밍 (27)
        • C++ STL (0)
        • 뇌를 자극하는 C++ STL (5)
      • -------- 생명과학 -------- (0)
      • 생화학 (5)
        • 대학 강의 (5)
      • 분자세포생물학 (3)
        • 대학 강의 (3)
      • 유전자치료공학 (2)
        • 대학 강의 (2)
      • 생명정보학 (5)
        • 대학 강의 (5)
      • 약리학 (2)
        • 대학 강의 (2)
      • -------- 컴퓨터과학 -------- (0)
      • 자료구조와 알고리즘 (8)
        • 자료구조와 알고리즘의 정의 (3)
        • [책 정리] C언어로 쉽게 풀어쓴 자료구조 요약 (1)
        • [인강] 자료구조와 알고리즘 (2)
        • 코딩 테스트 대비하기! (1)
      • 컴퓨터 회로 (0)
      • 컴퓨터 구조 (43)
        • 컴퓨터 구조와 운영체제 요약 (1)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 구조 및 설계 (1)
        • Ch1. 컴퓨터 추상화 및 관련 기술 (8)
        • Ch2. 명령어 : 컴퓨터 언어 (11)
        • Ch3. 컴퓨터 연산 (8)
        • Ch4. 프로세서 (11)
        • Ch5. 메모리 계층구조 (3)
        • Ch6. 병렬 프로세서 : 클라이언트에서 클라우드까지 (0)
      • 시스템 프로그래밍 (15)
        • [책 정리] 시스템 프로그래밍 유닉스 & 리눅스 (0)
        • [인강] 리눅스 시스템 프로그래밍 (2)
        • 리눅스에서 코딩이란? (8)
        • 대학교 강의 정리 (5)
      • 운영체제 (0)
      • 컴퓨터 네트워크 (37)
        • 모두의 네트워크 요약 (1)
        • [책 정리] 모두의 네트워크 (10)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 네트워킹 하향식 접근 8판 (1)
        • Ch1. 컴퓨터 네트워크와 인터넷 (7)
        • Ch2. 애플리케이션 계층 (7)
        • Ch3. 트랜스포트 계층 (8)
        • Ch4. 네트워크 계층 : 데이터 평면 (3)
        • Ch5. 네트워크 계층 : 제어 평면 (0)
        • Ch6. 링크 계층과 근거리 네트워크 (0)
        • Ch7. 무선 및 이동 네트워크 (0)
        • Ch8. 컴퓨터 네트워크 보안 (0)
      • 데이터베이스 (1)
      • -------- 데이터과학 -------- (0)
      • 데이터 사이언스 (8)
        • 인강 (8)
      • 데이터 분석 (2)
        • 인강 (2)
      • 머신러닝 (2)
        • 대학 수업 (2)
      • 인공지능 (11)
        • 대학교 강의 정리 (10)
        • 인공지능 관련 정보 (1)
      • -------- +a -------- (0)
      • Visual Studio Community (7)
        • 설치법 (1)
        • 단축키 (1)
        • 오류 (5)
      • Visual Studio Code (0)
      • 노션 (1)
      • 깃허브 (7)
        • 깃허브 사용법 (5)
        • 유니티, 언리얼 & 깃허브 (1)
        • 깃허브 주의사항 (1)
      • 챗GPT 활용법 (0)
      • 기타 feat. 프로그래밍 (7)
        • 프로그래머로 살아남기 (5)
        • 코딩 vs 프로그래밍 (1)
        • 애플 비전 프로 (1)
      • 메타버스 (5)
      • -------- 예술 -------- (0)
      • 음악 (1)
      • 미술 (0)
      • -------- XR -------- (0)
      • 유니티 이야기 (23)
        • 레트로의 유니티 게임 프로그래밍 에센스 요약 (4)
        • 유니티 관련 정보 (1)
        • 유니티 디버깅 (13)
        • 유니티 인강 (3)
        • 대학교 게임 프로그래밍 강의 (2)
      • 언리얼 이야기 (0)
        • 인생 언리얼 교과서 요약 (0)
      • 컴퓨터 그래픽스 (6)
        • OpenGL (6)
      • 가상현실 & 증강현실 (4)
        • 유니티 vr (4)
      • HCI 와 UI UX (7)
        • [책 정리] HCI 개론 (6)
      • -------- Design -------- (0)
      • 캐릭터 (1)
        • 모델링 (0)
        • 리깅 (1)
      • 포토샵 (3)
      • 3ds Max (7)
      • Maya (9)
        • 블로그 (1)
        • 인강 (6)
        • 대학교 (2)
      • Blender (14)
        • 책 (1)
        • 인강 (7)
        • 기타 (3)
        • 대학교 (3)
      • 아트 작업물들 (2)
      • 에셋 사이트 (1)
      • -------- 건강관리 -------- (0)
      • 건강관리 ft. 정현 (12)
        • 목 디스크 (2)
        • 눈 관리 (2)
        • 일상생활 습관 (6)
        • 일상생활 꿀팁 (2)
        • 사무직 꿀팁 (0)
      • 헬스의 정석 ft. 정현 (28)
        • 헬스와 건강 (8)
        • 헬스 구체화 정보 (6)
        • 헬스 유튜버 (1)
        • 헬스 서적 (1)
        • 도전 바디프로필! (11)
        • 헬스장 패션 (1)
      • -------- etc -------- (0)
      • 진로 관련 잡다한 글들 (34)
        • 진도율 (9)
        • 진로 관련 글들 (15)
        • 학교 강의 관련 글들 (10)
      • 인생 꿀 Tip (23)
        • 컴퓨터 초기 설정 (9)
        • 원격 데스크톱 (1)
        • 노트북 발열 (1)
        • 전자기기 (2)
        • 중고기기 팔기 (1)
        • 아이패드 필기 어플 (1)
        • 에어팟 (1)
        • 커피 (1)
        • 맥북 (1)
        • lg 그램 (1)
        • 검색엔진에서 내 티스토리 검색 (1)
        • hELLO 다크 모드 없애기 (1)
        • 인터넷 연결 문제 (1)
        • 키보드 문제 해결 (1)
      • 유튜브 (3)
      • 청춘 그리고 추억 (1)
      • 인생 계획표 (2)
        • 2024년 2학기 (1)
        • 2024년 여름방학 (0)
        • 2024년 1학기 (0)
        • 2023년 겨울방학 (1)
      • 다양한 글들 (98)
        • C++ STL (6)
        • Win32 API (24)
        • PushPush 게임 (13)
        • 컴퓨터구조 (1)
        • 자료구조와 알고리즘 (50)
        • 게임의 정의 (3)
        • 영상 회사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

    • Dream
    • 코딩을 시작한 이유
    • 나를 소개합니다!
    • 블로그 공부법
    • IT & 가치 있는 일들
  • 인기 글

  • 태그

    컴퓨터 네트워크
    리눅스 터미널
    C언어
    스택
    건국대
    데이터과학
    연산자
    유니티
    심리학
    C++
    함수
    코드잇
    생물정보학
    자료구조
    의생명공학
    명령어
    데이터사이언스
    AI
    인공지능
    생명공학
    컴퓨터구조
    포인터
    블렌더
    C++ STL
    의생명공학과
    unity
    알고리즘
    리눅스
    배열
    첨단바이오공학부
  • 최근 댓글

  • hELLO· Designed By정상우.v4.10.3
smile blog
2. 스택의 구현
상단으로

티스토리툴바