创建: 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下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...
随机推荐
- [转] angular2-highcharts用法详解
1. 使用npm安装angular2-highcharts npm install angular2-highcharts --save 2.主模块中引入 app.module.ts import { ...
- POJ1222熄灯问题【位运算+枚举】
EXTENDED LIGHTS OUT Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14231 Accepted: 8 ...
- 客户端用plsql进行中文条件查询时无结果的解决办法
1.SELECT * FROM v$nls_parameters ; 查看NLS_CHARACTERSET 的值是多少,我的AL32UTF8- 查找客户机器的注册表,查找NLS_LANG的值,改成AL ...
- hdu1978
{ scanf( { scanf( ;i<n;i++) ;j<m;j++) scanf( ...
- 2017年12月14日 一个Java开发的Python之路----------------(二)
说一个收获最大的,就是这个关闭流对象 之前写java读取文件的时候,最后往往要关闭流对象,以前我一直不明白,为什么,我不使用.close()方法,文件也可以读取成功,总感觉没有什么意义 原来是因为,这 ...
- onclick方法和$("").click()有不一样的地方
话说是这样的...昨天写了一个文件上传的功能,是这样的,用fastdfs上传成功后会有一个url... 然后我自己测试上传,包括在文件服务器里都能找到.. 然后就自己打包发版了,都很正常也没报错... ...
- SaltStack学习系列之state常用模块
常用模块:cron,cmd,file,mount,ntp,pkg,service,user,group cmd模块 参数: name:要执行的命令 unless:用于检查的命令,只有unless指向的 ...
- golang 跨平台编译——go 在windows上编译Linux平台的程序(Cross Compilation from Windows to Linux/Ubuntu)
Go Cross Compilation from Windows to Linux/Ubuntu I have GO 1.7 installed on my Windows 10. I create ...
- Cracking the Coding Interview 150题(二)
3.栈与队列 3.1 描述如何只用一个数组来实现三个栈. 3.2 请设计一个栈,除pop与push方法,还支持min方法,可返回栈元素中的最小值.pop.push和min三个方法的时间复杂度必须为O( ...
- Windows网络编程:winsock文件传输范例
基于TCP流协议的winsock网络文件传输Demo: 实现:C语言 功能:文件传输(可以传任何格式的文件) /******************************************** ...