创建: 2018/01/15
更新: 2018/01/24 更改标题 [【WIP_S3】堆] => [【WIP_S4】堆]
继续添加内容
更新: 2018/05/13 更改标题 [【WIP_S4】堆] => [【WIP_S4】栈]
所有[堆]替换成[栈]
| 栈 |
| 特点 |
一种数据结构
后入后处(LIFO)
放入: push
取出(最后一个): pop
|
| 什么时候用栈 |
后入后厨,就是新来的事务更重要,要先处理的情况 |
| 栈的ADT |
| 主要的栈运算 |
● push(int data) :插入栈
|
| ● int pop() :获取最后的元素并从栈删除 |
| 辅助的栈运算 |
● int top() : 不取出,只是获取最后的元素
|
|
● int size() : 获取栈内元素个数
|
|
● int isEmptyStatck() :是否为空
|
| ● int isFullStatck() : 是否已满 |
| 例外 |
pop空栈
push满栈
|
| |
|
|
| 应用 |
● 记号的平衡?# TODO: check [p82意思]
● 中置式变换为后置式 # TODO: check [p82意思]
● (包含递归的)函数呼出的实现
● 跨度运算 # TODO: check [p82意思]
● 浏览器的访问历史(返回按钮)
● 文本编辑器的返回功能
● HTML和XML的标签匹配吧
|
|
实现1
纯数组实现
|
//------------------------------------------------
// 型声明
//------------------------------------------------
#define PRO_STACK_SIZE_V1 100
struct arrayStack {
int top; //开头的索引
int capacity; // 容量
int *array;
};
//------------------------------------------------
// 函数声明
//------------------------------------------------
struct arrayStack *createStack(void);// 创建栈
int isEmptyStack(struct arrayStack *s); // 判断是否为空
int isFullStack(struct arrayStack *s);// 判断是否已满
void push(struct arrayStack *s, int data); // push
int pop(struct arrayStack *s); //pop
void deleteStack(struct arrayStack *s); // 删除栈
//------------------------------------------------
//
//
//------------------------------------------------
struct arrayStack *createStack() { // 创建栈
struct arrayStack *s = (struct arrayStack *)malloc(sizeof(struct arrayStack));
if (s == NULL) {
puts("单纯数组版,栈初始化失败");
return NULL;
}
s->capacity = PRO_STACK_SIZE_V1;
s->top = -;
s->array = malloc(s->capacity * sizeof(int));
if (s->array == NULL) {
puts("单纯数组版, 栈数据初始化失败");
return NULL;
}
return s;
}
int isEmptyStack(struct arrayStack *s) { // 判断是否为空
return (s->top == -); // 条件成立返回1(真), 不成立返回0(否)
}
int isFullStack(struct arrayStack *s) { // 判断是否已满
return (s->top >= (s->capacity -));
}
void push(struct arrayStack *s, int data) { // push
if (isFullStack(s)) {
puts("栈已满");
return;
} else {
s->array[++s->top] = data; //插入到最后一个的后面
}
}
int pop(struct arrayStack *s) { //pop
if (isEmptyStack(s)) {
puts("栈为空");
return ;
}else {
return s->array[s->top--]; // 返回最后一个并把top-1
}
}
void deleteStack(struct arrayStack *s) { // 删除栈
if (s) {
if (s->array) {
free(s->array);
}
free(s);
}
}
|
|
实现2
动态数组实现
|
数组满了就换一个两倍长度的
//------------------------------------------------
// 型声明
//------------------------------------------------
#define PRO_STACK_SIZE_V2 100
struct dynArrayStack {
int top;
int capacity;
int *array;
};
//------------------------------------------------
// 函数声明
//------------------------------------------------
struct dynArrayStack *createStackDyn(void);// 创建栈
int isEmptyStackDyn(struct dynArrayStack *s); // 判断是否为空
int isFullStackDyn(struct dynArrayStack *s);// 判断是否已满
void doubleStackDyn(struct dynArrayStack *s); // 双倍栈数据容量
void pushDyn(struct dynArrayStack *s, int data); // push
int topDyn(struct dynArrayStack *s); // 查看最后一个元素
int popDyn(struct dynArrayStack *s); //pop
void deleteStackDyn(struct dynArrayStack *s); // 删除栈
//------------------------------------------------
// 函数实现
//------------------------------------------------
struct dynArrayStack *createStackDyn(void) { // 创建栈
struct dynArrayStack *s = (struct dynArrayStack *)malloc(sizeof(struct dynArrayStack));
if (s == NULL) {
puts("动态数组版, 初始化失败");
return NULL;
}
s->capacity = PRO_STACK_SIZE_V2;
s->top = -;
s->array = (int *)malloc(s->capacity * sizeof(int));
if (s->array == NULL) {
puts("动态数组版,栈数据初始化失败");
return NULL;
}
return s;
}
int isEmptyStackDyn(struct dynArrayStack *s) { // 判断是否为空
return s->top == -;
}
int isFullStackDyn(struct dynArrayStack *s) { // 判断是否已满
return (s->top == s->capacity-);
}
void doubleStackDyn(struct dynArrayStack *s) { // 双倍栈数据容量
s->capacity = s->capacity*;
s->array = realloc(s->array, s->capacity);
if (s->array == NULL) {
puts("动态数组版,加长栈容量失败");
return;
}
}
void pushDyn(struct dynArrayStack *s, int data) { // push
if (isFullStackDyn(s)) {
doubleStackDyn(s);
}
s->array[++s->top] = data;
}
int topDyn(struct dynArrayStack *s) { // 查看最后一个元素
if (isEmptyStackDyn(s)) {
return INT_MIN; // 在limits.h里
}
return s->array[s->top];
}
int popDyn(struct dynArrayStack *s) { // pop
if (isEmptyStackDyn(s)) {
return INT_MIN;
}
return s->array[s->top--];
}
void deleteStackDyn(struct dynArrayStack *s) { // 删除栈
if (s) {
if (s->array) {
free(s->array);
}
free(s);
}
}
|
|
实现3
链表实现
|
//------------------------------------------------
// 型声明
//------------------------------------------------
struct listNodeStack {
int data;
struct listNodeStack *next;
};
//------------------------------------------------
// 函数声明
//------------------------------------------------
//struct listNodeStack *createStackList(void);// 不用创建
int isEmptyStackList(struct listNodeStack *s); // 判断是否为空
//int isFullStackList(struct listNodeStack *s);// 永不满
void pushList(struct listNodeStack **s, int data); // push
int topList(struct listNodeStack *s); // top 查看最后一个元素
int popList(struct listNodeStack **s); //pop
void deleteStackList(struct listNodeStack **s); // 删除栈
//------------------------------------------------
// 函数实现
//------------------------------------------------
int isEmptyStackList(struct listNodeStack *s) { // 判断是否为空
return s == NULL;
}
void pushList(struct listNodeStack **s, int data) { // push
struct listNodeStack *temp;
temp = (struct listNodeStack *)malloc(sizeof(struct listNodeStack));
if (temp == NULL) {
puts("链表版, push, 生成新节点失败");
return;
}
temp->data = data;
temp->next = *s;
*s = temp;
}
int topList(struct listNodeStack *s) { // top 查看最后一个元素
if (isEmptyStackList(s)) {
return INT_MIN;
}
return s->data;
}
int popList(struct listNodeStack **s) { //pop
struct listNodeStack *temp;
int data;
if (isEmptyStackList(*s)) {
return INT_MIN;
}
temp = *s;
*s = temp->next;
data = temp->data;
free(temp);
return data;
}
void deleteStackList(struct listNodeStack **s) { // 删除栈
struct listNodeStack *current, *temp;
current = *s;
while (current) {
temp = current;
current = current->next;
free(temp);
}
*s = NULL;
}
|
| |
|
- 通往全栈工程师的捷径 —— react
腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...
- Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)
--reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...
- duang~免费的学习视频来啦:学霸君之全栈测试
学霸君向童鞋们推荐一款 同名学霸学习 视频教程 重点是完全免费收看学习噢!!! 今天 学霸君推荐腾讯课堂的学霸君之全栈测试 复制下方链接至腾讯课堂中报名学习 https://ke.qq.com/cou ...
- [数据结构]——链表(list)、队列(queue)和栈(stack)
在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...
- BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]
1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 8748 Solved: 3835[Submi ...
- BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]
4453: cys就是要拿英魂! Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 90 Solved: 46[Submit][Status][Discu ...
- BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2326 Solved: 1054[Submit][Status ...
- .NET全栈开发工程师学习路径
PS:最近一直反复地看博客园以前发布的一条.NET全栈开发工程师的招聘启事,觉得这是我看过最有创意也最朴实的一个招聘启事,更为重要的是它更像是一个技术提纲,能够指引我们的学习和提升,现在转载过来与各位 ...
- Nodejs之MEAN栈开发(八)---- 用户认证与会话管理详解
用户认证与会话管理基本上是每个网站必备的一个功能.在Asp.net下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...
随机推荐
- Codeforces Round #413 B T-shirt buying (STL set)
链接:http://codeforces.com/contest/799/problem/B 题意: 给定n件衣服,对于第i(1<i<=n)件衣服,分别有价格pi,前颜色ai,后颜色bi三 ...
- Swagger UI教程
文档源地址 http://www.68idc.cn/help/makewebs/qitaasks/20160621620667.html Swagger-UI本身只提供在线测试功能,要集成它还需要告诉 ...
- 三菱PLC FB库函数调用方法 (Gx Work2版本)
本文以 GxWorks2 软件为例 1.新建使用标签项目的工程文件 2.从其它库所在工程项目中导入库 3.选择库文件及FB功能块 4.插入FB功能块调用
- python标准库笔记
1.python互联网数据处理模块 base64数据编码 二进制数据 encode ASCII字符 ASCll字符 decode 二进制数据 json数据交换格式 轻量的数据交换格式,json暴露的A ...
- python用模块zlib压缩与解压字符串和文件的方法
摘自:http://www.jb51.net/article/100218.htm Python标准模块中,有多个模块用于数据的压缩与解压缩,如zipfile,gzip, bz2等等. python中 ...
- msp430入门编程04
msp430中C语言的变量与数据类型 msp430入门学习 msp430入门编程
- CentOS虚拟机与本机同步时间
接着之前的任务,还是为了在VMWare上搭建分布式hadoop集群.搭着搭着注意到虚拟机上的时间和本机是不同步的,而且可以说是乱七八糟,3台虚拟机时间都与本机差了8个小时以上.首先确认不是时区的问题, ...
- [bzoj3712][PA2014]Fiolki_倍增LCA
Fiolki bzoj-3712 PA-2014 题目大意:题目链接. 注释:略. 想法: 神题! 我们建树:对于一次倾倒操作,我们弄一个新的大瓶子作为两个合并瓶子的父亲节点,与两个瓶子相连. 对于一 ...
- server证书安装配置指南(Tomcat 6)
一. 生成证书请求 1. 安装JDK 安装Tomcat须要JDK支持. 假设您还没有JDK的安装.则能够參考 Java SE Development Kit (JDK) 下载. 下载地址: ...
- Django学习系列之django restframework
曾几何时,Ajax已经统治了Web开发中的客户端,而REST成为web世界中最流行的架构风格(architecture style).所以我们的选择变得很简单:前端ajax访问后端的RESTful A ...