链栈的表示和实现

本文介绍了链栈的概念和特点,包括只在链表头部进行操作、不需要头结点等,并给出了链栈初始化、判断栈空、入栈、出栈和获取栈顶元素的C语言实现代码。这些操作在数据结构和算法中具有重要意义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

准备工作

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
#include<windows.h>
//函数结果状态字符
#define TRUE  1 
#define FALSE 0
#define OK    1
#define ERROR 0
#define INFEASIBLE   -1
#define OVERFLOW     -2

链栈是运算受限的单链表,只能在链表头部进行操作

1.链表的头指针就是栈顶

2.不需要头结点

3.基本不存在栈满的情况

4.空栈相当于头指针指向空

5.插入和删除仅在栈顶处执行

typedef struct StackNode
{
    SElemType data;
    struct StackNode *next;
}StackNode, *LinkStack;
LinkStack S;

链栈的初始化

void InitStack(LinkStack &S)
{
    //构造一个空栈
    S = NULL;
    return OK;
}

判断链栈是否为空

Status StackEmpty(LinkStack S)
{
    if(S==NULL) return TRUE;
    else return FALSE;
}

链栈的入栈(头插法)

Status Push(LinkStack &S, SElemType e)
{
    p = new StackNode;  //生成新节点
    p->data = e;        //将新节点数据域置为e
    p->next = S;        //将新节点插入栈顶
    S = p;              //修改栈顶指针
    return OK;
}

链栈的出栈

Status Pop(LinkStack &S, SElemType &e)
{
    if(S==NULL)  return ERROR;
    e = S->data;
    p = S;
    S = S->next;
    delete p;
    return OK;
}

取栈顶元素

SElemType GetTop(LinkStack S)
{
    if(S!=NULL)
    return S->data;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值