首页 > 其他分享 >【数据结构】栈和队列

【数据结构】栈和队列

时间:2024-05-26 13:00:28浏览次数:23  
标签:ps NULL 队列 assert Queue 数据结构 stack

栈和队列

栈:一种特殊的线性表,其中允许在固定的一端进行插入和删除元素操作,进行数据插入和删除操作的一段称为栈顶,另一端称为栈底,栈中的数据元素遵守后进先出的原则

  • LIFO(lost in first out)

压栈:栈的插入操作叫进栈\压栈\入栈,入数据在栈顶
出栈:栈的删除操作叫做出栈,出数据也在栈顶

栈的实现

栈的实现一般可以使用数组或者链表,相比较而言数组的结构实现更优一些,数组在尾部插入数据代价较小
在这里插入图片描述

这里简单讲一下,在数据结构中的栈与计算机组成原理中的栈是不同的,是俩个不同学科的内容。

stack.h文件

#define  _CRT_SECURE_NO_WARNINGS 1	

#include<stdio.h>
#include<assert.h>
#include<stdbool.h>
#include<stdlib.h>

//静态栈
//typedef int SLDataType;
//#define N 10
//typedef struct stack
//{
//	SLDataType SL[N];
//	int top;
//}stack;

//动态栈
typedef int SLDataType;
typedef struct stack
{
	SLDataType* SL;
	//栈顶
	int top;
	//容量
	int capacity;
}stack;

//初始化栈
void StackInit(stack* ps);

//销毁栈
void StackDestory(stack* ps);

//入栈
void StackPush(stack* ps,SLDataType x);

//出栈
void StackPop(stack* ps);

//获取栈顶元素
SLDataType StackTop(stack* ps);

//获取栈中有效元素个数
int StackSize(stack* ps);

// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0
bool StackEmpty(stack* ps);

stack.c文件

#include"stack.h"

//初始化栈
void StackInit(stack* ps)
{
	ps->SL = (SLDataType*)malloc(sizeof(SLDataType) * 5);
	if (ps == NULL)
	{
		perror("malloc fail");
		return;
	}
	ps->capacity = 5;
	ps->top = 0;
}

//销毁栈
void StackDestory(stack* ps)
{
	assert(ps);
	free(ps->SL);
	ps->SL = NULL;

	ps->capacity = 0;
	ps->top = 0;
}

//入栈
void StackPush(stack* ps, SLDataType x)
{
	assert(ps);
	if (ps->top == ps->capacity)
	{
		SLDataType* p = (SLDataType*)malloc(sizeof(SLDataType) * ps->capacity * 2);
		if (p == NULL)
		{
			perror("malloc fail");
			return;
		}
		ps->SL = p;
		p = NULL;
		ps->capacity *= 2;
	}
	ps->SL[ps->top] = x;
	ps->top++;
}

//出栈
void StackPop(stack* ps)
{
	assert(ps);
	assert(!StackEmpty(ps));
	ps->top--;
}

//获取栈顶元素
SLDataType StackTop(stack* ps)
{
	assert(ps);
	return ps->SL[(ps->top) - 1];
}

//获取栈中有效元素个数
int StackSize(stack* ps)
{
	assert(ps);
	return ps->top - 1;
}

// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0
bool StackEmpty(stack* ps)
{
	assert(ps);

	return (ps->top == 0);
}

队列

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先出先进FIFO(First in First Out)

入队列:进行插入操作的一端称为队尾
出队列:进行删除操作的一端称为对头

一端插入一端删除

在这里插入图片描述

队列的实现

队列的实现一般使用链表的形式

queue.h文件

#pragma once
#define  _CRT_SECURE_NO_WARNINGS 1	


#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>


typedef int QDataType;
//小环境:使用单链表形式表示队列
typedef struct QListNode
{
	QDataType data;
	struct QListNode* next;
}QNode;

//大环境:表示队列结构
typedef struct Queue
{
	QNode* head;
	QNode* tail;
	int size;
}Queue;

//队列初始化
void QueueInit(Queue* q);

//队列销毁
void Queuedestory(Queue* q);

//队尾入队列
void QueuePush(Queue* q,QDataType x);

//队头出队列
void QueuePop(Queue* q);

//获取队列头元素
QDataType QueueFront(Queue* q);

//获取队列尾元素
QDataType QueueBack(Queue* q);

//获取队列中有效元素个数
int QueueSize(Queue* q);

//检查是否为空
bool QueueEmpty(Queue* q);

queue.c文件

#include"queue.h"

//队列初始化
void QueueInit(Queue* q)
{
	assert(q);
	q->head = NULL;
	q->tail = NULL;
	q->size = 0;
}


//队尾入队列
void QueuePush(Queue* q, QDataType x)
{
	assert(q);
	QNode* newnode = (QNode*)malloc(sizeof(QNode));
	if (newnode == NULL)
	{
		perror("malloc fail");
		return;
	}
	newnode->next = NULL;
	newnode->data = x;
	if (q->head == NULL && q->tail == NULL)
	{
		q->head = q->tail = newnode;
	}
	else
	{
		q->tail->next = newnode;
		q->tail = newnode;
	}
	q->size++;
}

//队头出队列
void QueuePop(Queue* q)
{
	assert(q);
	assert(!QueueEmpty(q));
	if (q->head->next == NULL)
	{
		free(q->head);
		q->head = q->tail = NULL;
	}
	else
	{
		QNode* cur = q->head;
		q->head = cur->next;
		free(cur->next);
		cur = NULL;
	}
	q->size--;
}

//获取队列头元素
QDataType QueueFront(Queue* q)
{
	assert(q);
	assert(!QueueEmpty(q));

	return q->head->data;
}

//获取队列尾元素
QDataType QueueBack(Queue* q)
{
	assert(q);
	assert(!QueueEmpty(q));

	return q->tail->data;
}

//获取队列中有效元素个数
int QueueSize(Queue* q)
{
	assert(q);
	
	return q->size;
}

//检查是否为空
bool QueueEmpty(Queue* q)
{
	assert(q);

	return q->head == NULL;
}


//队列销毁
void Queuedestory(Queue* q)
{
	assert(q);
	QNode* cur = q->head;
	while (q->size == 0)
	{
		q->head = cur->next;
		free(cur);
		cur = q->head;
		q->size--;
	}
	cur = NULL;
	q->head = NULL;
	q->tail = NULL;
}

在这里插入图片描述

标签:ps,NULL,队列,assert,Queue,数据结构,stack
From: https://blog.csdn.net/dab112/article/details/139074119

相关文章

  • 数据结构与算法学习(05)查找(2)索引——BUAA
    文章目录查找(2)——索引介绍索引的基本概念稠密索引非稠密索引——分块索引多级索引查找(2)——索引介绍本文为查找第二部分,主要是整理了本人上课时讲的内容索引的基本概念索引:记录关键字值与记录的存储位置之间的对应关系索引文件:由基本数据与索引表两部分组成的......
  • 数据结构与算法学习(07)查找(4)散列、哈希、字典——BUAA
    文章目录查找(4)——散列(Hash)字典介绍散列函数的构造方法直接地址法数字分析法平方取中法叠加法移位叠加法折叠叠加法基数转换法除留余数法随机数法一些好的哈希函数**针对字符串好的哈希函数冲突的处理方法开放地址法线性探测二次探测伪随机特点再散列法链接地址法代......
  • 数据结构与算法学习(06)查找(3)Trie树(C语言)——BUAA
    文章目录查找(3)——Trie树(C语言)介绍结构实现典型应用(字典树)代码实现优势查找(3)——Trie树(C语言)介绍本文为查找第三部分,主要是整理了本人上课时讲的内容,并给出了C语言代码实现结构实现键值由固定的字符序列组成(如数字或字母),如Huffman码、英文单词;对应结点的分层标记......
  • 【Java学习】第39节:基础数据结构(二):链表
    目录1. 链表1)概述2)单向链表3)单向链表(带哨兵)4)双向链表(带哨兵)5)环形链表(带哨兵)习题E01.反转单向链表-Leetcode206E02.根据值删除节点-Leetcode203E03.删除倒数节点-Leetcode19E04.有序链表去重-Leetcode83E05.有序链表去重-Leetcode82E06.合......
  • 软考高级之redis中使用zset实现延迟队列,你答对了么?
    实现延迟队列的思路zset的特性,带有分数的排序,以时间戳作为分数进行排序添加任务zdd取出任务zrangbyscore执行任务zrem定时任务publicstaticvoidmain(String[]args){Jedisjedis=newJedis("ip",6379);TimerTasktask=newTimerTask()......
  • 栈和队列4 顺序栈的应用实例(迷宫求解)
    #include<stdio.h>#include<stdlib.h>#defineINITSIZE100#defineINCREAMENT10#defineM8#defineN8typedefstruct{   intx;   inty;}PosType;typedefstruct{   intord;   PosTypeseat;   intdi;}SElemType;typedefstructS......
  • 【数据结构】栈和队列
    个人主页~栈和队列一、栈1、概念2、栈的实现Stack.hStack.ctest.c二、队列1、概念2、队列的实现Queue.hQueue.ctest.c三、深入了解栈和队列的特性1、用队列实现栈2、用栈实现队列3、循环队列一、栈1、概念栈是一种特殊的线性表,只允许在固定的一端进行插入和......
  • 【数据结构与算法 | 基础篇】单向链表模拟栈
    1.前言前文我们先后用单向循环链表,环形数组来模拟了队列.队列的特点是先进先出.队头移除元素,队尾添加元素.所以需要两个指针控制.本文我们接下来提及如果和单向链表来模拟栈.栈的特点是后进先出.在栈顶压栈或弹栈.另一侧不动的是栈底.我们可以初始化哨兵节点,自哨兵节......
  • 【数据结构与算法 | 基础篇】数组模拟栈
    1.前言前文我们刚提及了如何用单向链表来模拟栈.我们还可以用数组来模拟栈.使用栈顶指针top来进行栈顶的操作.2.数组模拟栈(1).栈接口publicinterfacestack<E>{//压栈booleanpush(Evalue);//弹栈,栈非空返回栈顶元素Epop();//返回栈......
  • 复习数据结构的第五天(栈)
    上次我们复习了静态链表,它需要系统提前分配一定大小的内存空间,同时它和单链表一样有一个指针(游标)指向下一个节点的数组下标索引。它不具有顺序表随机访问的功能,但它可以像单链表一样插入删除时不需要移动其他元素,只需要改变游标就可以实现。栈的概念栈是一种只能在一端进行插......