【数据结构】栈

栈(数组模拟)

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

括号匹配

相关推荐
啊我不会诶2 小时前
Codeforces Round 1076 (Div. 3) vp补题
算法·深度优先
Bear on Toilet2 小时前
递归_二叉树_49 . 路径综合Ⅲ
数据结构·算法·前缀和·深度优先·递归
CHANG_THE_WORLD2 小时前
深入指针3 - 完全精讲版
数据结构·算法
im_AMBER2 小时前
Leetcode 124 二叉搜索树的最小绝对差 | 二叉树的锯齿形层序遍历
数据结构·学习·算法·leetcode·二叉树
ADDDDDD_Trouvaille2 小时前
2026.2.14——OJ78-82题
c++·算法
Hag_202 小时前
LeetCode Hot100 560.和为K的子数组
数据结构·算法·leetcode
田里的水稻3 小时前
FA_规划和控制(PC)-规律路图法(PRM)
人工智能·算法·机器学习·机器人·自动驾驶
追随者永远是胜利者3 小时前
(LeetCode-Hot100)23. 合并 K 个升序链表
java·算法·leetcode·链表·go
ab1515173 小时前
2.16完成107、108、111
算法