创建: 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;
}
   

【WIP_S4】栈的更多相关文章

  1. 通往全栈工程师的捷径 —— react

    腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...

  2. Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)

    --reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...

  3. duang~免费的学习视频来啦:学霸君之全栈测试

    学霸君向童鞋们推荐一款 同名学霸学习 视频教程 重点是完全免费收看学习噢!!! 今天 学霸君推荐腾讯课堂的学霸君之全栈测试 复制下方链接至腾讯课堂中报名学习 https://ke.qq.com/cou ...

  4. [数据结构]——链表(list)、队列(queue)和栈(stack)

    在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...

  5. BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]

    1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 8748  Solved: 3835[Submi ...

  6. BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]

    4453: cys就是要拿英魂! Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 90  Solved: 46[Submit][Status][Discu ...

  7. BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]

    3238: [Ahoi2013]差异 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2326  Solved: 1054[Submit][Status ...

  8. .NET全栈开发工程师学习路径

    PS:最近一直反复地看博客园以前发布的一条.NET全栈开发工程师的招聘启事,觉得这是我看过最有创意也最朴实的一个招聘启事,更为重要的是它更像是一个技术提纲,能够指引我们的学习和提升,现在转载过来与各位 ...

  9. Nodejs之MEAN栈开发(八)---- 用户认证与会话管理详解

    用户认证与会话管理基本上是每个网站必备的一个功能.在Asp.net下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...

随机推荐

  1. Hermite (埃尔米特)曲线

    Hermite 曲线 已知曲线的两个端点坐标P0.P1,和端点处的切线R0.R1,确定的一条曲线. 参数方程 1. 几何形式 2. 矩阵形式 3. 推导 例子分析 如上图有四个点,假如P0.P2是端点 ...

  2. 【Codeforces 1117C】Magic Ship

    [链接] 我是链接,点我呀:) [题意] 题意 [题解] 我们可以把这个行船的过程分解成两个过程 1.船经过时间t被风吹到了某个地方 2.船用这t时间尝试到达终点(x2,y2) 会发现如果时间t能最终 ...

  3. bash shell & front-end & auto publish & auto deploy

    bash shell & front-end & auto publish & auto deploy $ zip -r apitool-2018-11-22.zip apit ...

  4. swagger & api & swagger ui

    swagger & api swagger ui # run server $ swagger project start api-app # call api $ curl http://1 ...

  5. 2017 CCPC 杭州 HDU6265B 积性函数

    题目链接 http://acm.hdu.edu.cn/downloads/CCPC2018-Hangzhou-ProblemSet.pdf B题 数论题      h(n)=∑ d|n φ(d) × ...

  6. POJ 3083_Children of the Candy Corn

    题意: 给定迷宫图,求出一个人从入口进,从出口出,所走过的最短路径以及分别沿着左手边和右手边的墙走出迷宫所走过的方格数. 分析: bfs求最短路 对于沿左右两边的墙走的情况,记录好行走的方向及相对应的 ...

  7. 51Nod——T 1686 第K大区间

    https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1686 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 ...

  8. VMware配置从U盘启动

    很遗憾,VMware的BIOS不能识别USB启动设备,即使已经把USB设备连接上去. 解决这一问题的做法是直接添加硬盘,硬盘指向物理硬盘,即USB设置. 注意:Ubuntu下要设置这一功能需要使用su ...

  9. Servlet的HTTP状态码

    以下内容引用自http://wiki.jikexueyuan.com/project/servlet/http-status-codes.html: HTTP请求的格式和HTTP响应消息的格式是相似的 ...

  10. swift container server 莫名stuck

    openstack swift container server的进程经常莫名其妙进入 D Ds等状态 记录一下这个时候 storage.error的log 便于分析 一种情形是下面这种log Jun ...