1、栈:仅在表尾进行插入和删除操作的线性表。后进先出LIFO。

1)表尾端(允许插入和删除的一端)为栈顶,表头端(不允许插入和删除的一端)为栈底。

2)入栈:插入元素的操作。出栈:删除栈顶元素

3)栈的应用:数值转化、括号匹配检验、行编辑程序、迷宫求解、表达式求值

2、栈的两种存储表示方式

1)顺序栈(栈的顺序存储结构):利用一组地址连续的存储单元一次存放自栈底到栈顶的数据元素,同时附设指针top指示栈顶元素在顺序栈中的位置。top=0表示空栈。

2)链栈(栈的链式存储结构);优点是便于多个栈共享存储空间和提高效率。

3、括号匹配检验

1)左括号,则进栈。

2)右括号,若栈为空,则右括号多。

3)右括号,与栈顶元素比较,若相等则左括号出栈,若不相等则不匹配。

4)表达式检验结束时,若栈空则匹配成功,否则左括号多。

4、栈的基本操作

InitStack(&S):构造空栈

DestroyStack(&S):销毁栈

ClearStack(&S):清空栈

StackEmpty(S):判断栈是否为空,若为空则返回true,否返回false

StackLength(S):返回栈的长度

GetTop(S,&e):用e返回栈的栈顶元素

Push(&S,e):插入e为新栈顶

Pop(&S,&e):删除栈顶元素,并用e返回其值。

5、共享栈:利用栈底位置相对不变性的特性,使得两个顺序栈共享一个一维数据空间,将两个栈底设置在共享空间的两端。

1)top0=-1时0号栈为空,top1=maxsize时1号栈为空,仅当两个栈顶指针相邻(top1-top0=1)时,栈满。

2)当0号栈进栈时top0先加1再赋值,1号栈进栈时top1先减1在赋值。

6、栈的顺序存储类型描述

#define maxsize 50
typedef struct {
 int data[maxsize];
 int top;//栈顶指针,初始时设置S.top=-1,栈顶元素为:S.data[S.top],栈空条件:S.top==-1栈满条件:S.top==maxsize-1栈长:S.top+1
}Sqstack;
1)初始化栈
void initstack(Sqstack &S)
{
 S.top = -1;
}
2)判断栈空
bool stackempty(Sqstack S)
{
 if (S.top == -1)
 {
  return true;
 }
 else
 {
  return false;
 }
}
3)进栈
bool push(Sqstack &S, int e)
{
 if (S.top == maxsize - 1)
 {
  return false;
 }
 S.data[++S.top] = e;
 return true;
}
5)出栈
bool pop(Sqstack &S, int &e)
{
 if (S.top == -1)
 {
  return false;
 }
 e = S.data[S.top--];
 return true;
}
6)读栈顶元素
bool GetTop(Sqstack S, int &e)
{
 if (S.top == -1)
 {
  return false;
 }
 e = S.data[S.top--];
 return true;
}
7、栈的链式存储结构类型描述
typedef struct Linkstack {
 int data;
 struct Linkstack *next;
}*Listack;
8、一些基本问题的解决
1)以IO分别表示入栈和出栈操作,栈的初态和终态都为空,可以操作的序列称为合法序列,判断序列是否合法。
int judge(cha A[])
{
 int i = j = k = 0;
 while (A[i]!='\0')
 {
  switch (A[i])
  {
  case 'I':j++;
   break;
  case 'O':k++;
   if (k > j)
   {
    printf("序列非法\n");
    exit(0);
   }
  }
  i++;
 }
 if (j != k)
 {
  printf("序列非法");
  return false;
 }
 else
 {
  printf("序列合法");
  return true;
 }
}
2)设栈S1,S2都擦用顺序栈,并共享一个存储区[0,...,maxsize-1],采用栈顶相向、迎面增长的存储方式,出栈和入栈的实现。i为栈号,i=0表示左边的栈s1,i=1表示右边的栈s2,e为入栈元素。
typedef struct {
 int stack[maxsize];
 int top[2];
}stk;
stk s;
//入栈
int push1(int i, int e)
{
 if (i < 0 || i>1)
 {
  printf("栈号输入错误");
  exit(0);
 }
 if (s.top[1] - s.top[0] == 1)
 {
  printf("栈以满\n");
  return 0;
 }
 switch (i)
 {
 case 0:s.stack[++s.top[0]] = e;
  return 1;
  break;
 case 1:s.stack[--s.top[1]] = e;
  return 1;
 }
}
//出栈
int pop1(int i)
{
 if (i < 0 || i>1)
 {
  printf("栈号输入错误\N");
  exit(0);
 }
 switch (i)
 {
 case 0:
  if (s.top[0] == -1)
  {
   printf("栈空\n");
   return -1;
  }
  else
  {
   return s.stack[s.top[0]--];
  }
 case 1:
  if (s.top[1] == maxsize)
  {
   printf("栈空\n");
   return -1;
  }
  else
  {
   return s.stack[s.top[1]++];
  }
 }
}

数据结构(C语言版)---栈的更多相关文章

  1. 数据结构C语言版-栈

    #include <stdio.h> #include <stdlib.h> #include <math.h> #include <iostream> ...

  2. c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...

  3. 数据结构C语言版 有向图的十字链表存储表示和实现

    /*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...

  4. 数据结构C语言版 表插入排序 静态表

    数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./*  数据结构C语言版 表插入排序  算法10.3 P267-P270  编译 ...

  5. 数据结构C语言版 弗洛伊德算法实现

    /* 数据结构C语言版 弗洛伊德算法  P191 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h>#include <limits.h> # ...

  6. 《数据结构-C语言版》(严蔚敏,吴伟民版)课本源码+习题集解析使用说明

    <数据结构-C语言版>(严蔚敏,吴伟民版)课本源码+习题集解析使用说明 先附上文档归类目录: 课本源码合辑  链接☛☛☛ <数据结构>课本源码合辑 习题集全解析  链接☛☛☛  ...

  7. 【数据结构(C语言版)系列二】 栈

    栈和队列是两种重要的线性结构.从数据结构角度看,栈和队列也是线性表,但它们是操作受限的线性表,因此,可称为限定性的数据结构.但从数据类型角度看,它们是和线性表大不相同的两类重要的抽象数据类型. 栈的定 ...

  8. 深入浅出数据结构C语言版(8)——后缀表达式、栈与四则运算计算器

    在深入浅出数据结构(7)的末尾,我们提到了栈可以用于实现计算器,并且我们给出了存储表达式的数据结构(结构体及该结构体组成的数组),如下: //SIZE用于多个场合,如栈的大小.表达式数组的大小 #de ...

  9. 深入浅出数据结构C语言版(7)——特殊的表:队列与栈

    从深入浅出数据结构(4)到(6),我们分别讨论了什么是表.什么是链表.为什么用链表以及如何用数组模拟链表(游标数组),而现在,我们要进入到对线性表(特意加了"线性"二字是因为存在多 ...

  10. 数据结构(C语言版)顺序栈相关算法的代码实现

    这两天完成了栈的顺序存储结构的相关算法,包括初始化.压栈.出栈.取栈顶元素.判断栈是否为空.返回栈长度.栈的遍历.清栈.销毁栈.这次的实现过程有两点收获,总结如下: 一.清楚遍历栈的概念 栈的遍历指的 ...

随机推荐

  1. springboot2 + mybatis 多种方式实现多数据配置

    业务系统复杂程度增加,为了解决数据库I/O瓶颈,很自然会进行拆库拆表分服务来应对.这就会出现一个系统中可能会访问多处数据库,需要配置多个数据源. 第一种场景:项目服务从其它多处数据库取基础数据进行业务 ...

  2. mysql两表合并,对一列数据进行处理

    加班一时爽,一直加班~一直爽~  欢迎收看http://www.996.icu/ 今天弄了下MySQL中两表合并的并且要处理一列数据,这列数据原来都是小写字母,处理时将这列数据改成驼峰命名的~~ 基本 ...

  3. 多线程之旅(ThreadPool 线程池)

    一.什么是ThreadPool 线程池(源码) 1.线程池顾名思义,有我们的系统创建一个容器装载着我们的线程,由CLR控制的所有AppDomain共享.线程池可用于执行任务.发送工作项.处理异步 I/ ...

  4. 写爬虫爬了3w条职位数据,看看当前招聘形势 | 开源

    最近有不少程序员又开始找工作了,为了了解目前技术类各职位的数量.薪资.招聘公司.岗位职责及要求,我爬取了拉勾网北上广深4个城市的招聘数据,共3w条.职位包括:人工智能(AI).大数据.数据分析.后端( ...

  5. 食物图片变菜谱:这篇CVPR论文让人人都可以学习新料理

    根据 Facebook 的统计,Instgram 上的美食图片数量已经超过 3 亿张.然而,获取食物烹饪方法的途径依然有限,例如,通过烹饪网站或相关教程.怎样能够挖掘丰富食物图片背后的烹饪方法,让每个 ...

  6. JavaScript 趣味题。

    第一题: const Greeters = [] for (var i = 0 ; i < 10 ; i++) { Greeters.push(function () { return cons ...

  7. POJ旅行商问题——解题报告

    旅行商问题 总时间限制: 1000ms 内存限制: 65536kB 描述 某国家有n(1<=n<=10)座城市,给定任意两座城市间距离(不超过1000的非负整数).一个旅行商人希望访问每座 ...

  8. iOS UmbrellaHeader

    Lexical or Preprocessor Issue - Umbrella header for module 'xxx' does not include header 'xxx.h' fra ...

  9. 【webpack 系列】进阶篇

    本文将继续引入更多的 webpack 配置,建议先阅读[webpack 系列]基础篇的内容.如果发现文中有任何错误,请在评论区指正.本文所有代码都可在 github 找到. 打包多页应用 之前我们配置 ...

  10. 基于Java的数字货币交易系统的架构设计与开发

    前言 无论是股票交易系统,还是数字货币交易系统,都离不开撮合交易引擎,这是交易平台的心脏.同时,一个优秀的架构设计也会让交易平台的运维和持续开发更加容易.本文基于对开源项目的深入研究,总结了数字货币交 ...