这篇文章将为大家详细讲解有关C语言中怎么实现链栈,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
链栈图解
链栈的常规操作
LinkStack InitLinkStack();// 初始化链栈int StackEmpty();// 判断链栈空int StackLength();// 求链栈长(链栈元素个数)int Push();// 入栈 压栈ElemType Pop();// 出栈 弹栈void DestroyStack();// 销毁链栈
定义链栈结构体
#include "stdio.h"#include "malloc.h"#define TRUE 1#define FALSE 0typedef int ElemType;// 链栈存储元素的数据类型typedef struct Node{ElemType data;// 栈结点数据域struct Node *next;// 栈结点指针域}*LinkStack, Node;
初始化链栈
// 初始化链栈(带头结点的链栈)LinkStack InitLinkStack(){LinkStack s = (LinkStack)malloc(sizeof(struct Node));s -> next = NULL;return s;}
链栈判空
int StackEmpty(LinkStack s){if(s == NULL){return FALSE;}return s -> next == NULL;}
因为是链式存储结构,无需链栈判满。
计算链栈的长度
int StackLength(LinkStack s){LinkStack p;int len = 0;if(StackEmpty(s)){return FALSE;}p = s -> next;// 带头结点的链栈要先移动一下while(p != NULL){len ++;p = p -> next;}return len;}
链栈入栈(Push)
int Push(LinkStack s, ElemType data){// 分配入栈结点Node *new_node = (Node *)malloc(sizeof(struct Node));if (new_node == NULL) return FALSE;// 结点分配失败// 跟单链表一样使用头插法new_node -> data = data;new_node -> next = s -> next;s -> next = new_node;return TRUE;}
链栈出栈(Pop)
ElemType Pop(LinkStack s){LinkStack top;ElemType data;// 判栈空if(StackEmpty(s)){return FALSE;}top = s -> next;// 访问栈顶结点data = top -> data;// 取出栈顶元素s -> next = top -> next;free(top);// 释放栈顶空间return data;}
链栈各操作测试
// 程序主入口int main(int argc, char const *argv[]){LinkStack s = InitLinkStack();printf("StackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));// 入栈元素ElemType datas[] = {1, 3, 5, 7, 9};// 动态计算入栈元素个数int len = sizeof(datas) / sizeof(datas[0]);// for循环依次入栈printf("Push():");for(int i = 0; i < len; i++){printf("%d\t", datas[i]);Push(s, datas[i]);}printf("\nStackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));// 出栈 弹栈printf("Pop(): ");while(!StackEmpty(s)){printf("%d\t", Pop(s));}printf("\nStackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));return 0;}
结果如下:
StackEmpty():1StackLength():0Push():1 3 5 7 9StackEmpty():0StackLength():5Pop(): 9 7 5 3 1StackEmpty():1StackLength():0
C语言是什么
C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发,使用C语言可以以简易的方式编译、处理低级存储器。
关于“C语言中怎么实现链栈”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。