数据结构——栈与队列(C语言)

栈与队列



前言

本文就介绍了数据结构中两大基础存储结构,栈与队列的基础内容。


提示:以下是本篇文章正文内容,下面案例可供参考

一、栈是什么?

栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

二、队列是什么?

队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。

三、两者的区别

在这里插入图片描述
栈:后进先出(LIFO-last in first out):最后插入的元素最先出来。

队列:先进先出(FIFO-first in first out):最先插入的元素最先出来。

四、栈与队列的实现

1.栈的实现

1.1 引入库以及设置结构体

#include <stdio.h>
#include <malloc.h>
#define STACK_INT_SIZE  5
#define STACKINCREMENT  5

typedef struct 
{
   
	int *base;//栈底指针 
	int *top;//栈顶指针,始终在栈顶元素的下一个位置 
	int stacksize; //栈的容量 
}SqStack;

1.2初始化栈

int InitStack(SqStack &S)
{
   //创建一个空栈S 
	S.base =(int *)malloc(STACK_INT_SIZE*sizeof(int));
	if(!S.base)
	{
   
		printf("空间申请失败!");
		return -1;
	}
	S.top = S.base ;
	S.stacksize=STACK_INT_SIZE;
	return 1;
}

1.3元素插入功能的实现

int Push(SqStack &S,int e)
{
   //插入元素e为新的栈顶元素 
	if(S.top - S.base>=S.stacksize)//栈满,追加存储空间 
	{
   
		S.base =(
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值