数据结构----栈和队列
xdm这玩意我不会导入,只能截图了。
目录
栈篇
1.1栈
1.2.栈操作数据元素的两种动作:
2.代码实现
2.1初始化和销毁
2.2插入
2.3删除和判空
2.4返回栈顶值,计算栈长
队列篇
3.1队列
4.代码实现
4.1初始化和销毁和判空
4.2入列
4.3出列
4.4返回对首和队尾
栈篇
1.1栈
栈,线性表的一种特殊的存储结构。与学习过的线性表的不同之处在于栈只能从表的固定一端对数据进行插入和删除操作,另一端是封死的。由于栈只有一边开口存取数据,称开口的那一端为“栈顶”,封死的那一端为“栈底”(类似于盛水的木桶,从哪进去的最后还得从哪出来)。
1.2.栈操作数据元素的两种动作:
- 数据元素用栈的数据结构存储起来,称为“入栈”,也叫“压栈”。
- 数据元素由于某种原因需要从栈结构中提取出来,称为“出栈”,也叫“弹栈”。
注意:栈遵循先进后出原则
1.3.栈的表示方式
既然栈也是线性表,那么它就同样有线性表的两种表示形式: 顺序(数组)和 链式栈。
但是,栈需要进行尾部的插入和删除,所以用顺序表实现比链表实现更好。
2.代码实现
接下来就来实现这几大功能
#pragma once
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int SLDateType;
typedef struct Stack
{SLDateType* a;int top; //栈顶int capacity; //内存
}ST;//初始化
void StackInit(ST* ps);//销毁
void StackDestroy(ST* ps);//插入
void StackPush(ST* ps, SLDateType x);//删除
void StackPop(ST* ps);//返回栈顶值
void StackTop(ST* ps);//判断是否为空
bool StackEmpty(ST* ps);//计算栈长
int StackSize(ST* ps);
是不是你们的教科书上用的是双指针,或者,这个栈顶元素top也用指针了。但是这个还是不用指针更好一点,这个top既能表示栈顶,又能表示此时栈中所存储的数据个数,用途更多了。
2.1初始化和销毁
//初始化
void StackInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = ps->capacity = 0;
}//销毁
void StackDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = ps->capacity = 0;
}
初始化和销毁就这两步啊给指针a赋值NULL,给剩下俩赋值为0,
销毁就是释放指针,给那俩赋值为0。
2.2插入
//插入
void StackPush(ST* ps, SLDateType x)
{assert(ps);if (ps->top == ps->capacity)//判断容量{int newcapacity = (ps->capacity == 0 ? 4 : 2 * ps->capacity);//扩容后的容量SLDateType* tmp = realloc(ps->a, sizeof(SLDateType) * newcapacity);//扩容if (tmp == NULL){perror("realloc fail");exit(-1);}ps->capacity = newcapacity;ps->a = tmp;}ps->a[ps->top] = x ;//压入数据ps->top++;
}
最后一步压入数据是往结构体的a中压入的,又因为a是结构体指针,所以a中有top,所以把要插入的值存在top中,然后top++。
至于那个ps->a=tmp是把开辟好的地址给ps->a。
2.3删除和判空
//删除
void StackPop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));ps->top--;
}//判断是否为空
bool StackEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}
注意bool的头文件<stdbool.h>
2.4返回栈顶值,计算栈长
//返回栈顶值
SLDateType StackTop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));return ps->a[ps->top - 1];}//计算栈长
int StackSize(ST* ps)
{assert(ps);return ps->top;
}
队列篇
3.1队列
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。
注意:队列是先进先出。
一般我们用链来实现队列。
4.代码实现
typedef int QDataType;typedef struct QueueNode//链表
{QDataType data;struct QueueNode* next;
}QNode;typedef struct Queue//队列
{QNode* head;QNode* tail;
}Queue;
4.1初始化和销毁和判空
//初始化
void QueueInit(Queue* pd)
{assert(pd);pd->head = pd->tail = NULL;
}//销毁
void QueueDestroy(Queue* pd)
{assert(pd);QNode* cur = pd->head;while (cur){QNode* next = cur->next;free(cur);cur = next;}pd->head = pd->tail = NULL;
}//判空
int QueueEmpty(Queue* pd)
{if (pd->head == NULL){return 1;}elsereturn 0;
}
4.2入列
//入列
void QueuePush(Queue* pd, QDateType x)//入列
{assert(pd);QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){printf("malloc:falue");exit(-1);}newnode->data = x;newnode->next = NULL;//一个没有就进行插入if (pd->tail == NULL){pd->head = pd->tail = newnode;}else{pd->tail->next = newnode;pd->tail = newnode;}}
4.3出列
//出列
void QueuePop(Queue* pd)
{assert(pd);assert(!QueueEmpty(pd));if (pd->head->next == NULL){free(pd->head);pd->head = pd->tail = NULL;}else{QNode* next = pd->head->next; //保存下一个节点地址,防止找不到free(pd->head);pd->head = next;}
}
4.4返回对首和队尾
//返回队首
void QueueFront(Queue* pd)
{assert(pd);assert(!QueueEmpty(pd));return pd->head->data;
}//返回队尾
void QueueBack(Queue* pd)
{assert(pd);assert(!QueueEmpty(pd));return pd->tail->data;
}
这个返回首尾是看一位大佬的代码的临时启发,希望对各位有用。
一些代码没加备注,我认为各位都学到了这了,这些代码随便就来,就没写来凑字了。
总结:栈和队列都能用顺序表(数组)和链表来表示。再想想,这俩不就是链表的特殊情况吗,栈是后进先出,队列是先进先出,而链表(单,循环)是啥时候进出都可以,这不就是长方形里的正方形吗。
数据结构----栈和队列相关推荐
- 数据结构栈和队列_使您的列表更上一层楼:链接列表和队列数据结构
数据结构栈和队列 When you want to store several elements somewhere in a program, the go-to data type is an a ...
- 数据结构栈与队列的应用之汽车轮渡问题——自己的一些理解
本题摘自王道数据结构栈与队列的应用的课后题,题目如下: 某汽车轮渡口,过江渡船每次能载10辆汽车过江.过江车辆分为客车类和货车类,上渡船有如下规定:同类车先到先上船,客车先于货车上船,且每上4辆客车, ...
- 数据结构——栈与队列相关题目
数据结构--栈与队列相关题目 232. 用栈实现队列 思路 225. 用队列实现栈 1.两个队列实现栈 2.一个队列实现栈 20. 有效的括号 思路 1047. 删除字符串中的所有相邻重复项 思路 1 ...
- 第十章 基本数据结构——栈和队列
摘要 本章介绍了几种基本的数据结构,包括栈.队列.链表以及有根树,讨论了使用指针的简单数据结构来表示动态集合.本章的内容对于学过数据结构的人来说,没有什么难处,简单的总结一下. 1.栈和队列 栈和队列 ...
- 大话数据结构-栈与队列
文章知识点来至于大话数据结构里边章节知识, 这篇主要介绍栈与队列在计算机中存储形式, 以及在某些算法领域中对栈和队列的相关应用.章节最后介绍了著名的逆波兰表达式, 以及通过算法来实现该表达式的运算过程 ...
- 数据结构——栈与队列操作(用栈模拟队列)
[栈与队列操作] 问题描述:假设有两个长度相同的栈 S1,S2,已知以下入栈.出栈.判栈满和判栈空操作: void Push(S,x); Elemtype Pop(S); bool StackFull ...
- 【数据结构-栈和队列】详解栈和队列(代码+STL+原理)
一.栈的应用 栈是一种先进后出(FILO)的数据结构 1.1 栈的操作实现 清空(clear): // 栈的清空操作就是把栈顶top置为-1 void clear(){top=-1; } // 清空栈 ...
- 算法与数据结构 -- 栈与队列(四)
栈与队列定义了数据的操作 一.栈 栈是一种先入先出的数据结构.可以用顺序表实现,也可以用链表实现 栈操作 判断是否为空 压栈.入栈push 出栈 pop 返回栈顶元素 peek 栈的元素个数 # co ...
- 六十二、数据结构栈和队列的相互实现
@Author:Runsen 编程的本质来源于算法,而算法的本质来源于数学,编程只不过将数学题进行代码化. ---- Runsen 算法,一门既不容易入门,也不容易精通的学问. 栈和队列都是用来保存数 ...
- 数据结构栈和队列以及常见算法题
栈 概念:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作.进行数据插入和删除操作的一端称为栈顶,另一端称为栈底.栈中的数据元素遵守后进先出LIFO(Last In First Out)的 ...
最新文章
- 功能强大的打包工具 NSIS,全部用脚本搞定 使用经验总结帖(持续更新中。。。)...
- IOS7 开发注意事项
- [渝粤教育] 东南大学 工程热力学 参考 资料
- LeetCode 1668. 最大重复子字符串
- 阿里云超算异构Spot集群,助力深势科技30%成本驱动MDaaS海量算力
- 【Tensorflow】Tensorflow中的卷积函数(conv2d、slim.conv2d、depthwise_conv2d、conv2d_transpose)
- 【Docker】Error: No such image: gotok8s/kube-proxy:v1.16.5
- odoo10参考系列--测试模块
- win11设置打开闪退怎么办,解决win11系统闪退的问题
- 两阶段目标检测详解--FasterRCNN
- 全民社会保障月供制度的客观理由
- 51系列单片机IO模试设置
- html制作心形状图片,把多张图片拼接成一个爱心的形状 爱心形状的图片效果 爱心拼接照...
- 企业微信管理客户如何管理?
- 产品读书《谁说菜鸟不会数据分析(入门篇)》
- 采集网站服务器配置,搭建数据采集云服务器源码
- 三国群英传霸业之王服务器维护,20200825维护公告
- 82---Python 动态绘制阻尼振荡
- “同声传译”的难度有多大?
- Witt向量简介 §2.2:Witt向量的代数背景