C/C++ 예제

시삽: 레드플러스 님 
게시판 이동:
 제목 : 13.1.1. 스택(Stack)
글번호: 244
작성자: 레드플러스
작성일: 2005/12/07 오전 11:45:41
조회수: 3800
/*
    Stack : 스택에 데이터를 저장하는 Push 함수와 데이터를 추출하는 Pop 함수를 작성한다.
*/
#include <stdio.h>

#define MaxSize 100        /* 스택 크기 */
int stack[MaxSize];        /* 스택 */
int sp = 0;                /* 스택 포인터 */
int Push(int);
int Pop(int*);

//메인 함수
int main(void)
{
    int c, n;
    printf("]");
    while((c = getchar()) != EOF)
    {
        if(c == '\n') continue;
        if(c == 'i' || c == 'I')
        {
            printf("data--> ");
            scanf("%d", &n);
            if(Push(n) == -1)
            {
                printf("스택이 가득 찼습니다.\n");
            }
        }
        if(c == 'o' || c == 'O')
        {
            if(Pop(&n) == -1)
            {
                printf("스택이 비었습니다.\n");
            }
            else
            {
                printf("stack data--> %d\n", n);
            }
        }
        printf("]");
    }

    return 0;
}

//스택에 데이터를 저장하는 함수
int Push(int n)
{
    if(sp < MaxSize)
    {
        stack[sp] = n;
        sp++;
        return 0;
    }
    else
    {
        return -1;//스택이 가득 찼을 때
    }
}

//스택에서 데이터를 추출하는 함수
int Pop(int *n)
{
    if(sp > 0)
    {
        sp--;
        *n = stack[sp];
        return 0;
    }
    else
    {
        return -1;//스택이 비었을 때
    }
}
 
이전 글   다음 글 삭제 수정 답변 글쓰기 리스트

(댓글을 남기려면 로그인이 필요합니다.)

관련 아티클 리스트
  제       목 파일 작성자 작성일 조회
이전글 14. 기타 - 레드플러스 2005-07-26 4785
  13. 데이터 구조(자료 구조) - 레드플러스 2005-07-26 5270
  13.1. 스택(Stack) - 레드플러스 2005-12-07 3622
현재글 13.1.1. 스택(Stack) - 레드플러스 2005-12-07 3800
  스택 및 큐에 대한 설명한 엑셀 파일(강의용) 스택큐설명.xls(15 KB) 레드플러스 2007-01-23 3827
  13.2. 큐(Queue) - 레드플러스 2005-12-07 3576
  13.2.1. 큐(Queue) - 레드플러스 2005-12-07 4065
  13.2.1.1. 큐(Queue)에 대해 설명할 때 사용한 엑셀 파일 스택큐설명2.xls(15 KB) 레드플러스 2007-01-25 3653
  13.3. 리스트(List) - 레드플러스 2005-12-07 3760
  13.3.1. 리스트(List) : LIFO형 리스트 - 레드플러스 2005-12-07 3730
  13.3.1.1. 리스트(List) : LIFO형 리스트 설명시 사용했던 엑셀 파일 리스트(LIFO)설명.xls(13 KB) 레드플러스 2007-01-26 3639
  13.3.2. 리스트(List) : FIFO형 리스트 - 레드플러스 2005-12-07 4053
  13.3.2.1. 리스트(List) : FIFO형 리스트 설명시 사용했던 엑셀 파일 리스트(FIFO)설명.xls(13 KB) 레드플러스 2007-01-26 3672
  13.3.3. 리스트(List) 입력 - 레드플러스 2005-12-08 3802
  13.3.4. 리스트(List) 삭제 - 레드플러스 2005-12-08 3641
  13.3.5. 이중 연결 리스트(Doubly Linked List) - 레드플러스 2005-12-08 6927
  13.3.6. 이중 연결 리스트 간단한 설명 : 이중연결리스트간단한설명.c - 레드플러스 2007-01-24 4726
  13.3.6. 이중 연결 리스트 간단한 설명시 사용했던 엑셀 파일 이중연결링크드리스트설명.xls(13 KB) 레드플러스 2007-01-24 3886
  13.4. 트리(Tree) - 레드플러스 2006-05-01 3624
  13.4.1. 이진 탐색 트리 - 레드플러스 2006-05-01 3925
  13.4.1.1. 이진 탐색 트리 설명시 사용했던 엑셀 파일 트리설명.xls(17 KB) 레드플러스 2007-01-25 3798
  13.5. 그래프(Graph) - 레드플러스 2006-05-02 3559
  13.5.1 그래프(Graph) - 레드플러스 2006-05-02 3581
  13.5.1.1 그래프(Graph) 설명시 사용했던 엑셀 파일 그래프설명.xls(15 KB) 레드플러스 2007-01-25 3771
  13.6. 해시테이블(Hashtable) - 레드플러스 2006-05-03 3743
  13.6.1 해시테이블(Hashtable) - 레드플러스 2006-05-03 4709
  데이터 구조 종합 예제 : 주소록 프로그램 종합예제_주소록프로그램.c(9 KB) 레드플러스 2006-11-02 4261
다음글 12. 메모리 관리 - 레드플러스 2005-07-26 5080
 
손님 사용자 Anonymous (손님)
로그인 Home