c语言顺序栈、链栈
admin
2024-04-01 08:47:27
0

栈(Stack)是只允许在一端进行插入或删除操作的线性表。其特点是他的元素后进先出(Last In First Out (LIFO))。
在实现栈的时候需要设置一个成员用于存放栈顶游标(top)(储存栈顶元素的位置信息),有的把最后一个元素的下标作为栈顶记录。

顺序栈

设顺序栈为S,需要注意的如下:

入栈:
栈满时 S.top-S.base==S.stacksize

出栈:
栈空时 S.top == S.base

取栈顶元素:
++会改变自身值,而-1不会改变,故返回*(S.top-1);

顺序栈特点:
由于顺序栈和顺序表一样, 受到最大空间容量的限制, 虽然可以在 “满员” 时重新分配空间扩大容量, 但工作量较大,因此在应用程序无法预先估计栈可能达到的最大容量时,应该尽量避免使用顺序栈。
 

#include
#include

#define MAXSIZE 100
typedef int SElemType;

//顺序栈的存储结构
typedef struct
{
    SElemType *base;
    SElemType *top;
    int stacksize;            //可用最大容量
}SqStack;

//初始化
void InitStack(SqStack &S)
{
    S.base = new SElemType[MAXSIZE];
    if (!S.base) exit;    
    S.top = S.base;
    S.stacksize = MAXSIZE;
}

//入栈
int Push(SqStack &S, SElemType e)
{
    if (S.top - S.base == S.stacksize) return 0;    //栈满

    *S.top = e;
    S.top++;
    return 1;
}

//出栈
int Pop(SqStack &S, SElemType &e)
{
    if (S.top == S.base) return 0;    //栈空

    S.top--;
    e = *S.top;
    return 1;
}

//取栈顶元素
SElemType GetTop(SqStack S)
{
    if (S.top != S.base)     //非栈空时返回
        return *(S.top-1);   //++会改变指针自身值,而-1不会改变
}

//遍历输出栈
void printStack(SqStack S)
{
    printf("栈底:");
    SElemType *p = S.base;
    while (p!=S.top)
    {
        printf("%d ", *p);
        p++;
    }
    printf("\n");
}

int main()
{
    SqStack S;
    int e;
    InitStack(S);
    printf("请输入一个要入栈的元素(-1表示结束):");
    scanf("%d",&e);
    while (e!=-1)
    {
        Push(S,e);
        printf("请输入一个要入栈的元素(-1表示结束):");
        scanf("%d", &e);
    }
    printStack(S);
    printf("出栈测试:");
    Pop(S, e);
    printStack(S);

    printf("取栈顶元素测试:");
    e=GetTop(S);
    printf("取出的栈顶元素为:%d\n",e);
}
 

链栈

由于栈的主要操作是在栈顶插入和删除, 显然以链表的头部作为栈顶是最方便的,且不需要附加一个头结点。

初始化:

栈顶指针S置空即可。

#include
#include

#define MAXSIZE 100
typedef int SElemType;

//链栈的存储结构
typedef struct StackNode
{
    SElemType data;
    struct StackNode *next;
}StackNode,*LinkStack;

//初始化
void InitStack(LinkStack &S)
{
    S = NULL;    //构造一个空栈,栈顶指针置空即可
}

//入栈
int Push(LinkStack &S, SElemType e)
{
    //链栈不需要判断栈满

    StackNode *p = new StackNode;
    p->data = e;
    p->next = S;
    S = p;
    return 1;
}

//出栈
int Pop(LinkStack &S, SElemType &e)
{
    if (S==NULL) return 0;    //栈空

    StackNode *p = S;
    e = S->data;
    S = S->next;
    delete p;
    return 1;
}

//取栈顶元素
SElemType GetTop(LinkStack S)
{
    if (S!=NULL)     //非栈空时返回
        return S->data;   
}

//遍历输出栈
void printStack(LinkStack S)
{
    printf("栈顶->");
    StackNode *p = S;
    while (p!=NULL)
    {
        printf("%d ",p->data);
        p = p->next;
    }
    printf("\n");
}

int main()
{
    LinkStack S;
    int e;
    InitStack(S);
    printf("请输入一个要入栈的元素(-1表示结束):");
    scanf("%d",&e);
    while (e!=-1)
    {
        Push(S,e);
        printf("请输入一个要入栈的元素(-1表示结束):");
        scanf("%d", &e);
    }
    printStack(S);
    printf("出栈测试:");
    Pop(S, e);
    printStack(S);

    printf("取栈顶元素测试:");
    e=GetTop(S);
    printf("取出的栈顶元素为:%d\n",e);
}
 

相关内容

热门资讯

linux入门---制作进度条 了解缓冲区 我们首先来看看下面的操作: 我们首先创建了一个文件并在这个文件里面添加了...
C++ 机房预约系统(六):学... 8、 学生模块 8.1 学生子菜单、登录和注销 实现步骤: 在Student.cpp的...
A.机器学习入门算法(三):基... 机器学习算法(三):K近邻(k-nearest neigh...
数字温湿度传感器DHT11模块... 模块实例https://blog.csdn.net/qq_38393591/article/deta...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
Redis 所有支持的数据结构... Redis 是一种开源的基于键值对存储的 NoSQL 数据库,支持多种数据结构。以下是...
win下pytorch安装—c... 安装目录一、cuda安装1.1、cuda版本选择1.2、下载安装二、cudnn安装三、pytorch...
MySQL基础-多表查询 文章目录MySQL基础-多表查询一、案例及引入1、基础概念2、笛卡尔积的理解二、多表查询的分类1、等...
keil调试专题篇 调试的前提是需要连接调试器比如STLINK。 然后点击菜单或者快捷图标均可进入调试模式。 如果前面...
MATLAB | 全网最详细网... 一篇超超超长,超超超全面网络图绘制教程,本篇基本能讲清楚所有绘制要点&#...
IHome主页 - 让你的浏览... 随着互联网的发展,人们越来越离不开浏览器了。每天上班、学习、娱乐,浏览器...
TCP 协议 一、TCP 协议概念 TCP即传输控制协议(Transmission Control ...
营业执照的经营范围有哪些 营业执照的经营范围有哪些 经营范围是指企业可以从事的生产经营与服务项目,是进行公司注册...
C++ 可变体(variant... 一、可变体(variant) 基础用法 Union的问题: 无法知道当前使用的类型是什...
血压计语音芯片,电子医疗设备声... 语音电子血压计是带有语音提示功能的电子血压计,测量前至测量结果全程语音播报࿰...
MySQL OCP888题解0... 文章目录1、原题1.1、英文原题1.2、答案2、题目解析2.1、题干解析2.2、选项解析3、知识点3...
【2023-Pytorch-检... (肆十二想说的一些话)Yolo这个系列我们已经更新了大概一年的时间,现在基本的流程也走走通了,包含数...
实战项目:保险行业用户分类 这里写目录标题1、项目介绍1.1 行业背景1.2 数据介绍2、代码实现导入数据探索数据处理列标签名异...
记录--我在前端干工地(thr... 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前段时间接触了Th...
43 openEuler搭建A... 文章目录43 openEuler搭建Apache服务器-配置文件说明和管理模块43.1 配置文件说明...