【数据结构】栈

栈(数组模拟)

结构体定义
cpp 复制代码
typedef int StackData;
typedef struct StackNode
{
	StackData* a;
	int top;
	int capacity;
}Stack;
初始化
cpp 复制代码
void StackInit(Stack* st)
{
	assert(st);
	StackData* tmp = (StackData*)malloc(sizeof(StackData) * 4);
	if (tmp == NULL)
	{
		perror("malloc fail");
		return;
	}
	st->a = tmp;
	st->capacity = 4;
	st->top = -1;
}
销毁和判空
cpp 复制代码
void StackDestory(Stack* st)
{
	assert(st);
	st->a = NULL;
	st->top = st->capacity = 0;
}

bool Stack_Empty(Stack* st)
{
	return st->top == -1;
}
入栈和出栈
cpp 复制代码
void StackPush(Stack* st, StackData x)
{
	assert(st);
	if (st->top + 1 == st->capacity)
	{
		StackData* tmp = (StackData*)realloc(st->a, sizeof(StackData) * st->capacity * 2);
		if (tmp == NULL)
		{
			perror("realloc fail");
			return;
		}
		st->a = tmp;
		st->capacity *= 2;
	}
	st->a[++st->top] = x;
}
void StackPop(Stack* st)
{
	assert(st);
	assert(!Stack_Empty(st));
	st->top--;
读取个数和取顶部数据
cpp 复制代码
int StackSize(Stack* st)
{
	assert(st);
	return st->top + 1;
}

int StackTop(Stack* st)
{
	assert(st);
	assert(!Stack_Empty(st));
	return st->a[st->top];
}

括号匹配

相关推荐
爱吃提升9 小时前
Yifan Hu(适合大规模数据)大数据算法
开发语言·算法·php
Xpower 179 小时前
从PHM到AI Agent-如何用OpenClaw构建设备健康诊断智能体
网络·人工智能·学习·算法
洛水水9 小时前
【力扣100题】24. 旋转图像
算法·leetcode
样例过了就是过了9 小时前
LeetCode热题100 颜色分类
c++·算法·leetcode
ZPC82109 小时前
C++ 跨平台 UDP 收发测试程序
c++·算法·机器人
如君愿9 小时前
考研复习 Day 34 | 习题--计算机网络 第六章(应用层 下)、数据结构 查找算法(下)
数据结构·计算机网络·考研·课后习题
Languorous.9 小时前
数据结构初阶|二叉树入门,从零到一吃透基础
数据结构
ym_xixi9 小时前
《类和对象》—— 构造函数与析构函数总结
前端·c++·算法
洛水水9 小时前
【力扣100题】19. 排序链表 | 归并排序详解
算法·leetcode·链表
凯瑟琳.奥古斯特9 小时前
丑数II C++三指针解法(力扣264)
数据结构·c++·算法·leetcode·职场和发展