zoukankan      html  css  js  c++  java
  • 线性结构的常见应用之一 栈

    栈的定义:

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

        栈类似于箱子

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

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

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

        

    栈的算法:

          出栈

          压栈

    栈表的实现:

    # 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!
    ",val);
        } else {
            printf("出栈失败!
    ");
        }
        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("动态内存分配失败!
    ");
            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("
    ");
        return;
    }
    //压栈
    void push(PSTACK pS,int val) {
        PNODE pNew = (PNODE)malloc(sizeof(NODE));
        if(NULL == pNew->pNext) {
            printf("动态内存分配失败!
    ");
            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("栈为空
    ");
            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;
        }
    }
  • 相关阅读:
    php 单双引号的区别
    SpringBoot动态代理使用Cglib还是jdk的问题
    SpringBoot MyBatis 一级缓存和二级的配置理解
    SpringBoot+MyBatis,显示SQL方式
    java lambda分页
    关于Spring的@Value注解使用Integer方式
    mysql死锁,等待资源,事务锁,Lock wait timeout exceeded; try restarting transaction解决
    关于Integer包装类对象之间值的比较
    你未必了解的DNS
    SpringCloudConfig报错Cannot clone or checkout repository:https://gitee.com/yanfa401/config-repo
  • 原文地址:https://www.cnblogs.com/strator/p/7233334.html
Copyright © 2011-2022 走看看