简单了解 栈

简单了解 栈

思维导图

『 栈 』 是计算机存储中一种常见的简单数据结构

对 『 栈 』结构常进行的数据操作我们常称为 『 出栈 』( 读取或是删除数据 ) 或是 『 入栈 』( 插入数据 )
有个很形象的比喻 ,把 『 栈 』看成是一个子弹夹将数据压入和弹出,恰好的表达了『 栈 』的特性 『 后进先出 , 先进后出 』,而『 递归 』的使用就是和 『 栈 』紧密相连。( 递归 : 不断调用函数自己 。)

如何理解 栈

这是 王争 老师在 《 数据结构与算法之美 》 专栏中 『 栈:如何实现浏览器的前进和后退功能? 』稍作修改变成的 C# 代码 。( 两门语言因为历史原因惊人的相似 , 却因开源和闭源的问题而有了极大的差别的开发者数量 )

// 基于数组实现的顺序栈
    public class ArrayStack
    {
        private String[] items;  // 定义一个数组
        private int count;       // 栈中元素个数
        private int n;           // 栈的大小

        // 初始化数组,申请一个大小为 n 的数组空间
        public ArrayStack(int n)//构造函数 , 每次实例化对象时需传入参数 n 
        {
            this.items = new String[n];// 初始化栈数组的长度
            this.n = n; // 初始化私有变量 n 的值 , this.n 是指类中的变量 n
            this.count = 0; // 初始化 count 计数器的值为 
        }

        // 入栈操作
        public bool push(String item)
        {
            // 数组空间不够了,直接返回 false,入栈失败。
            if (count == n) return false;
            // 将 item 放到下标为 count 的位置,并且 count 加一
            items[count] = item;
            ++count;
            return true;
        }

        // 出栈操作
        public String pop()
        {
            // 栈为空,则直接返回 null
            if (count == 0) return null;
            // 返回下标为 count-1 的数组元素,并且栈中元素个数 count 减一
            String tmp = items[count - 1];
            --count;
            return tmp;
        }
    }

这是一个 C# 实现的 栈 类 ,表达的是数组实现的『 顺序栈 』,完全按照数据的录入顺序来执行压栈 。
代码解读 :
count 为计数器 , 但数组索引从 0 开始 , 所以每次录入数据之后 计数器 +1 ,而最后一个元素则为 items[ count-1 ] 。
而 栈 的结构也可以用链表来表示 , 实际上就是在链表头结点插入数据 , 又因为链表的从『 首到尾 』遍历特性每次从 起始位 也就是首结点开始读取数据 。 相比较数组实现栈 , 链表的实现更有灵活性, 便于动态扩充数据长度 , 而数组相对而言会节省内存, 灵活性稍差 。( 如果是动态数组 , 则会因为动态扩容增加算法的时间复杂度 , 在平摊时间复杂度分析法中 动态数组实现栈也是 O( 1 ) ,因为只有一种特殊情况 数据长度超出初始数组长度时执行扩容操作 , 特殊情况的时间复杂度为 O( n ) ,执行了一次数据拷贝 )

栈在函数中的应用

函数总是被嵌套 , 例如 其他函数总是被 main 函数( 主函数 )所嵌套 , 可以用『 栈 』的定义来思考函数嵌套。

/* 递归实现累加 , 假设 n 一定为正整数 */
int  recursion(int n)
{
    if (n == 1)
        return 1;
    else
        n=(n+recursion(n-1));
    return n;
}

在这个累加递归函数中 ,recursion 函数被不断调用 , 直到 n == 1 ;因为 『 栈 』的数据操作是 『 后进先出 』所以在计算机中 , 依次执行的是 1+ 2 + 3 .... + n ,而其他被嵌套的函数也是大致这样的过程 。先执行最里层的函数将数据不断返回到最外层 ,最终产生我们所需要的结果。

==栈的结构未必是计算机执行函数嵌套必然的选择 , 但是这样的结构更利于我们去理解 ,因为递归的思想符合我们人思考的逻辑 。也符合函数执行『 后进先出 』的特性。将二者联系一起考虑是一种好的方式。==

计算机中通过栈来实现算术运算

王争老师在课中将计算机执行算术运算用 『 栈 』的思想给我们讲解了一下。
例如 1 + 2 × 3 - 4
计算机执行运算的过程中将 数字 和 运算符分开存储在两个栈里。
先按输入顺序存放 , 在读取到 × 号等运算级别较高的算术运算符时 , 根据算术运算符将运算符 升到栈顶( 即执行 出栈 、 出栈 的一端),相应的 ,数字栈中对应的两端的数据上升。( 王争老师数字这一块的操作未指出,如有误导请 指正
按照『 栈 』思想运算顺序应当为 ① 2*3 ② 6-4 ③ 2+1

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,138评论 0 13
  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy阅读 9,514评论 1 51
  • 少平离开了双水村,去找属于自己的天地去了,第一次离开双水村和大哥父亲以及家里的一些人,第二次踏到黄原这片土地时,他...
    一个个小人物阅读 5,265评论 0 1
  • ◆◇ 学会管理好自己的时间 ◇◆ 我和女儿早就商量好了,如果本周女儿做作业效率高的话,周日上午学完小提琴之后就可以...
    勿忘初心丨阅读 194评论 0 0
  • 文/墨文 每当傍晚静的时候,才愿打开心灵,用心去聆听外面的世界,月光透过纱窗映照在钢琴旁喝了一半的红酒杯上,黑白相...
    艺术大观阅读 123评论 0 1