【数据结构】栈

栈(数组模拟)

结构体定义
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];
}

括号匹配

相关推荐
三毛的二哥5 小时前
BEV:典型BEV算法总结
人工智能·算法·计算机视觉·3d
南宫萧幕6 小时前
自控PID+MATLAB仿真+混动P0/P1/P2/P3/P4构型
算法·机器学习·matlab·simulink·控制·pid
故事和你917 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
我叫黑大帅7 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
炽烈小老头8 小时前
【每天学习一点算法 2026/04/20】除自身以外数组的乘积
学习·算法
skilllite作者8 小时前
AI agent 的 Assistant Auto LLM Routing 规划的思考
网络·人工智能·算法·rust·openclaw·agentskills
破浪前行·吴9 小时前
数据结构概述
数据结构·学习
py有趣10 小时前
力扣热门100题之不同路径
算法·leetcode
_日拱一卒10 小时前
LeetCode:25K个一组翻转链表
算法·leetcode·链表
啊哦呃咦唔鱼10 小时前
LeetCodehot100-394 字符串解码
算法