栈(考研复习)

一、采用顺序存储结构实现栈(即顺序栈)

总结:

Stack.h

cpp 复制代码
#pragma once
#include<stdio.h>
#include<stdbool.h>

#define MaxSize 10
typedef int ElemType;
// 采用顺序结构实现栈
// 定义栈的结构
typedef struct SqStack
{
	ElemType arr[MaxSize]; // 栈中最多可以存储MaxSize个ElemType类型的数据
	int top; // top是栈顶指针,指向栈顶元素
}SqStack;

// 栈的初始化
void Init(SqStack& S); 

// 判断栈是否为空。为空返回true,否则返回false。
bool Empty(SqStack S);

// 新元素x入栈
bool Push(SqStack& S, ElemType x);

// 删除栈顶元素(出栈操作),并将栈顶元素的值赋给变量e
bool Pop(SqStack& S, ElemType& e);


// 获取栈顶元素,并将栈顶元素的值赋给变量e
bool GetTop(SqStack S, ElemType& e);

Stack.cpp

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include"Stack.h"
// 栈的初始化
void Init(SqStack& S)
{
	S.top = -1;
}

// 判断栈是否为空。为空返回true,否则返回false
bool Empty(SqStack S)
{
	if (S.top == -1)
		return true;	// 栈为空
	else
		return false;	// 栈不为空
}

// 新元素x入栈
bool Push(SqStack& S, ElemType x)
{
	if (S.top == MaxSize - 1) // 此时表示栈中已经存满了元素,无法执行入栈操作
		return false;
	S.top++;
	S.arr[S.top] = x; // 将新元素x放到栈顶的位置
	return true;
}


// 删除栈顶元素(出栈操作),并将栈顶元素的值赋给变量e
bool Pop(SqStack& S, ElemType& e)
{
	if (S.top == -1) // 表示此时栈为空,无法执行出栈操作
		return false;
	e = S.arr[S.top]; // 将栈顶元素赋给e
	S.top--;
	return true;
}


// 获取栈顶元素,并将栈顶元素的值赋给变量e
bool GetTop(SqStack S, ElemType& e)
{
	if (S.top = -1)
		return false; // 表示栈为空,无法指向获取栈顶元素的操作
	e = S.arr[S.top];
	return true;
}

二、共享栈

共享栈就是两个栈共享同一片空间

cpp 复制代码
// 定义共享栈的结构(两个栈共享同一块内存,这两个栈分别命名为0号栈与1号栈)
# define MaxSize 10
typedef int ElmeType;
typedef struct ShStack {
	ElmeType data[MaxSize];
	int top0; // 0号栈的栈顶指针
	int top1; // 1号栈的栈顶指针
}ShStack;

// 共享栈的初始化
void InitStack(ShStack& S)
{
	S.top0 = 0;
	S.top1 = MaxSize;
}

// 共享栈满了的条件:S.top0+1 == S.top1
相关推荐
酉鬼女又兒8 小时前
零基础入门计算机网络网际层核心:IP数据报发送与转发完整流程、静态路由配置方法、路由环路成因与解决方案及历年考研经典例题深度解析
网络·tcp/ip·计算机网络·考研·职场和发展
酉鬼女又兒9 小时前
零基础入门IPv4地址:从基本概念、分类编址、子网划分到无分类编址与应用规划全解
网络·网络协议·计算机网络·考研·职场和发展·分类·智能路由器
killerbasd1 天前
总结 6.13
考研
05候补工程师2 天前
【408考研复习】数据结构核心笔记:字符串模式匹配与内部排序算法全解析
数据结构·经验分享·笔记·考研·算法·排序算法
乘~风3 天前
408考研-计组-1.2计算机系统层次结构笔记+1.3计算机性能指标
笔记·考研·408
killerbasd3 天前
总结 6.11
考研
唐维康3 天前
F00403综合程序设计考什么?昆工891复试全流程拆解
考研
2601_961845424 天前
高考真题试卷电子版|2025高考全科试卷分类下载
考研·面试·蓝桥杯·远程工作·程序员创富·高考
海绵宝龙4 天前
图形推理解题两步法:快速定位核心规律
考研
2601_961845425 天前
2027考研数学大纲|数一数二数三
考研·fpga开发·ar·vr·mr·oneflow