码迷,mamicode.com
首页 > 其他好文 > 详细

线性结构的常见应用之一 栈

时间:2017-07-25 22:45:25      阅读:275      评论:0      收藏:0      [点我收藏+]

标签:tom   size   tac   data   empty   span   next   main   void   

栈的定义:

    一种可以实现 " 先进后出 " 的存储结构。

    栈类似于箱子

栈的分类(主要是看存储的方式连续还是不连续):

    静态栈:以数组的形式生成的栈。

    动态栈:以链表的形式生成的栈。

    

栈的算法:

      出栈

      压栈

栈表的实现:

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

//先定义结点类型
typedef struct Node {
    int data;
    struct Node * pNext;
} NODE,*PNODE;

//定义一个栈

typedef struct Stack {
    PNODE pTop;
    PNODE pBottom;
} STATCK,*PSTACK;
//初始化一个栈
void init(PSTACK pS);
//遍历一个栈
void traverse(PSTACK pS);
//压栈
void push(PSTACK pS,int val);
//出栈
bool pop(PSTACK pS,int *val);
//clear
void clear(PSTACK pS);

int main(void) {
    STATCK S;
    int val;
    init(&S);
    push(&S,3);
    push(&S,4);
    push(&S,7);
    push(&S,9);
    traverse(&S);

    if(pop(&S,&val)) {
        printf("出栈的值是%d!\n",val);
    } else {
        printf("出栈失败!\n");
    }
    traverse(&S);
    clear(&S);//清空栈
    traverse(&S);//清空成功

    return 0;
}

//初始化栈
//初始化的目的就是将pTop和pBottom两个指针指向同一个没有实际意义的头结点这样就实现了栈的初始化
void init(PSTACK pS) {
    pS->pTop = (PNODE)malloc(sizeof(NODE));
    if(NULL == pS->pTop) {
        printf("动态内存分配失败!\n");
        exit(-1);
    } else {
        pS->pBottom = pS->pTop;
        pS->pTop->pNext = NULL;
    }
}
//遍历一个栈
void traverse(PSTACK pS) {
    PNODE p = pS->pTop;
    while(p!=pS->pBottom) {
        printf("%d   ",p->data);
        p = p->pNext;
    }
    printf("\n");
    return;
}
//压栈
void push(PSTACK pS,int val) {
    PNODE pNew = (PNODE)malloc(sizeof(NODE));
    if(NULL == pNew->pNext) {
        printf("动态内存分配失败!\n");
        exit(-1);
    }
    pNew->pNext = NULL;
    pNew->data = val;
    pNew->pNext = pS->pTop;
    pS->pTop = pNew;
    return;
}
bool empty(PSTACK pS) {
    if(pS->pTop == pS->pBottom) {
        return true;
    } else {
        return false;
    }
}
bool pop(PSTACK pS,int *val) {
    if(empty(pS)) {
        printf("栈为空\n");
        return false;
    } else {
        PNODE p = pS->pTop;
        *val = p->data;
        pS->pTop = p->pNext;
        free(p);
        p = NULL;
        return true;
    }
}

void clear(PSTACK pS) {
    if(empty(pS)) {
        return;
    } else {
        PNODE p;
        p = pS->pTop;
        PNODE q = NULL;
        while (p!=pS->pBottom) {
            q = p->pNext;
            free(p);
            p = q;
        }
        pS->pTop = pS->pBottom;
    }
}

 

线性结构的常见应用之一 栈

标签:tom   size   tac   data   empty   span   next   main   void   

原文地址:http://www.cnblogs.com/strator/p/7233334.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!