C语言链式栈

news/2024/11/25 4:29:39/

stack.h

typedef struct Node_s {int data;struct Node_s *pNext;
} Node_t, *pNode_t;typedef struct Stack_s {pNode_t pHead;//栈顶指针,指向了链表的第一个结点int size;//栈的元素个数
} Stack_t, *pStack_t;void init(pStack_t pStack);
void push(pStack_t pStack, int data);
int isEmpty(pStack_t pStack);
void pop(pStack_t pStack);
int top(pStack_t pStack);
int size(pStack_t pStack);

main.c

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "stack.h"
int main() {Stack_t stack;init(&stack);for (int i = 0; i < 5; ++i) {push(&stack, i);printf("top = %d\n", top(&stack));}for (int i = 0; i < 6; ++i) {pop(&stack);printf("pop, top = %d\n", top(&stack));}
}
//初始化
void init(pStack_t pStack) {memset(pStack, 0, sizeof(Stack_t));
}
//压栈
void push(pStack_t pStack, int data) {pNode_t pNew = (pNode_t)calloc(1, sizeof(Node_t));pNew->data = data;//这个链表只有pHead没有pTail,所以不用判断是否为空pNew->pNext = pStack->pHead;pStack->pHead = pNew;++pStack->size;
}
//判空
int isEmpty(pStack_t pStack) {return pStack->size == 0;
}
//弹栈
void pop(pStack_t pStack) {if (isEmpty(pStack)) {fprintf(stderr, "Stack is empty!\n");return -1;}pNode_t pCur = pStack->pHead;pStack->pHead = pCur->pNext;free(pCur);pCur = NULL;--pStack->size;
}
//获取栈顶数据
int top(pStack_t pStack) {if (isEmpty(pStack)) {fprintf(stderr, "Stack is empty!\n");return -1;}return pStack->pHead->data;
}
//获取栈的大小
int size(pStack_t pStack) {return pStack->size;
}

http://www.ppmy.cn/news/1227933.html

相关文章

C++学习 --vector

目录 1&#xff0c; 什么是vector 2&#xff0c; 创建vector 2-1&#xff0c; 标准数据类型 2-2&#xff0c; 自定义数据类型 2-3&#xff0c; 其他创建方式 3&#xff0c; 操作vector 3-1&#xff0c; 赋值 3-2&#xff0c; 添加元素 3-2-1&#xff0c; 添加元素(assi…

二元关系及关系代数中的象集、除运算

二元关系及关系代数中的象集、除运算 数学上&#xff0c;二元关系用于讨论两个数学对象的联系。诸如算术中的「大于」及「等于」&#xff0c;几何学中的"相似"&#xff0c;或集合论中的"为...之元素"或"为...之子集"。二元关系有时会简称关系&a…

46.全排列-py

46.全排列 class Solution(object):def permute(self, nums):""":type nums: List[int]:rtype: List[List[int]]"""# 结果数组0ans[]nlen(nums)# 判断是否使用state_[False]*n# 临时状态数组dp_[]def dfs (index):# 终止条件if indexn:ans.appe…

ubuntu20编译ffmpeg3.3.6

windows下的安装教程见&#xff1a;win10 下编译ffmpeg3.36.tar.gz-CSDN博客 windows下的安装其实是模仿ubuntu下的安装。 ubuntu下的安装过程如下&#xff1a; 1. 下载安装 make&#xff0c; gcc &#xff0c;diffutils&#xff0c; yasm &#xff0c;pkg-config 我是下载…

小米路由器AX1800降级后的SSH登录和关墙等命令

​​​​​​​​​​​​​​​​​​​​​http://192.168.31.1/cgi-bin/luci/;stok429aaa9c7f05ee7d0816a00257b8414a/api/misystem/set_config_iotdev?bssidXiaomi&user_idlongdike&ssid-h%3B%20nvram%20set%20ssh_en%3D1%3B%20nvram%20commit%3B%20sed%20-i%20s%…

【Python仿真】基于EKF的传感器融合定位

基于EKF的传感器融合定位&#xff08;Python仿真&#xff09; 简述1. 背景介绍1.1. EKF扩展卡尔曼滤波1.1.1.概念1.1.2. 扩展卡尔曼滤波的主要步骤如下&#xff1a;1.1.3. 优、缺点 1.2. 航位推算1.3. 目前航位算法的使用通常与卡尔曼滤波相结合使用2. 分段代码 2.1. 导入需要的…

Redis 访问控制列表(ACL)

Redis ACL 关于 Redis ACL与旧版本兼容ACL helpACL 配置模式redis.conf 配置模式外部 ACL File 配置模式 ACL 规则总结 关于 Redis ACL Redis ACL (访问控制列表) 是 Access Control List 的缩写&#xff0c;它允许某些连接在可以执行的命令和可以访问的密钥方面受到限制。它…

锐捷EG易网关login.php以及其后台cli.php/branch_passw.php RCE漏洞复现 [附POC]

文章目录 锐捷EG易网关login.php以及其后台cli.php/branch_passw.php远程代码执行漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现 锐捷EG易网关login.php以及其后台cli.php/branch_passw.php远程代码执行漏洞复…