创建: 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. vimtips阅读记录

    __BEGIN__ *vimtips.txt* For Vim version 8.0. ------------------------------------------------------- ...

  2. readdir() 获取文件类型

    readdir()获取文件类型 //// 字符设备文件 type =2, filename207=tty0 crw-rw----  1 root root     4,  0 04-10 16:28 ...

  3. Surprising Strings

    Surprising Strings Time Limit: 1000MS Memory Limit: 65536K Total Submissions: Accepted: Description ...

  4. [bzoj4826][Hnoi2017]影魔_单调栈_主席树

    影魔 bzoj-4826 Hnoi-2017 题目大意:给定一个$n$个数的序列$a$,求满足一下情况的点对个数: 注释:$1\le n,m\le 2\cdot 10^5$,$1\le p1,p2\l ...

  5. java.lang.NoClassDefFoundError: Could not initialize class异常处理

    借鉴:http://blog.csdn.net/sleepdancer/article/details/9207425 static { InputStream in = XXX.class.getR ...

  6. Analyzing Storage Performance using the Windows Performance Analysis ToolKit (WPT)

    https://blogs.technet.microsoft.com/robertsmith/2012/02/07/analyzing-storage-performance-using-the-w ...

  7. java编程思想-多态

    java中除了static方法和final方法(private方法属于final方法)之外,其他所有的方法都是动态绑定即运行时绑定. public class test { private void ...

  8. JS获取地址栏并拼接參数

    比方地址栏是这种:http://www.aa.com/detail.aspx?code=1&start=2014-12-01&end=2014-12-23&name=abc 要 ...

  9. andorid自己定义ViewPager之——子ViewPager滑到边缘后直接滑动父ViewPager

    近期的项目中,有一个需求要用ViewPager中嵌套ViewPager去实现整个效果.没做不论什么处理做出来后,仅仅能不停的滑动子ViewPager,父ViewPager就无法滑动了,这样肯定是不满足 ...

  10. 查看yarn当前执行任务列表

    Author: kwu 查看yarn当前执行任务列表.可使用例如以下命令查看: yarn application -list 如需杀死当前某个作业,使用kill application-id的命令例如 ...