入栈出栈序列问题

时隔将近三年,我又准备在简书上发文章了,初衷依然是将自己对一些算法的理解和感悟记录下来。今天开始动笔时看了一下自己当年发的第一篇文章,看了好久才看懂,我真是醉了。明明就是一个很简单的入栈出栈序列问题,非要讲得那么复杂,扯什么卡特兰数,都tm写的啥玩意儿。我觉得知识的感悟和理解切忌搞一堆看似高大上的概念,重要的是要知道这些概念背后的逻辑是什么,提出这些概念的人当时他们是怎么想出来的。所以我打算用自己的语言,言简意赅地把第一篇文章中的问题再梳理一遍。

问题描述

对一个栈进行n次入栈和n次出栈操作,问满足条件的入栈出栈序列一共有多少个?

问题分析

我先摊牌,文章一中的纸杯问题问题本质上就是这样一个题意非常简单的问题,我们先解这个简单问题,回过头来再仔细分析问题之间是如何转化的。

首先对于入栈出栈问题,毋庸置疑的是第一个操作一定是第一个元素x_{0} 入栈。考察x_{0} 出栈时的情况,x_{0} 的出栈将这n个元素分成了两个部分,一部分是在此之前进栈的元素(此时也已经全部出栈),另一部分是尚未进栈的元素。根据栈后入先出的特性,x_{0} 出栈时栈一定是空的,所以对于尚未进栈的那k个元素,完全就是一个子问题f(k),而对于已经进栈的元素,仅仅是在头尾分别加上了x_{0} 的入栈和出栈,本质上也是一个子问题,于是我们就得到了下面的公式:

f(n) = \sum_{k=0}^{n-1} f(k) * f(n-1-k)

其中f(0)*f(n-1)表示x_{0} 刚进栈就立即出栈的情况,f(n-1)*f(0)表示x_{0} 最后出栈的情况,怎么样,是不是一下子就豁然开朗。理解到这一步对于解决这个问题就已经足够了,具体的代码实现我就不写了,可以用递归也可以用动态规划。

问题转化

下面我就来具体讲一讲文章一中的纸杯问题是怎么转化成出栈入栈问题的。文章一传送门:不缠绕的纸杯电话,只看一下题目描述即可。问题是如何转化的这一点非常重要,因为许多问题本质上都是一类问题,只是披上了不同的外套。对于纸杯问题,我们首先抽取题意:在一个圆周上有2n个点,将它们两两相连且保证连线不相交,问共有多少种连线方式。首先我们在这2n个点中任选一个点作为起始点,因为这些点都是等价的,所以选谁都一样。为了便于分析,我们选择最上面的点p_{0} ,用这个点模拟栈中第一个元素的入栈。在剩下的2n-1个点中,我们选择一个点与p_{0} 相连,注意这条连线将整个圆分成了两个部分,左边和右边,因为连线不能相交,它们只能在各自的部分中两两相连。怎么样,是不是有一种似曾相识的感觉,我们又将这个问题分解成了两个子问题。为保证能够两两相连,两个部分的点的个数都必须是偶数,所以p_{0} 只能选择与p_{1} p_{3} ...p_{2n-1} 这些下标为奇数的n个点相连(假定下标是以逆时针方向增长的)。

那么怎么模拟其实就显而易见了,我们将连线中下标较小的点视为入栈,大点视为出栈,以p_{0} 为例,p_{0} p_{1} 就表示x_{0} 入栈后立即出栈,p_{0} p_{2n-1} 表示x_{0} 最后出栈。到了这一步是不是就发现,这个问题本质上就是入栈出栈序列问题,列出来的公式都是一模一样的。

扩展

看了上面的解答,下面这个问题你能解决吗:

n个高矮不同的人,排成两排,每排必须是从矮到高排列,而且第二排比对应的第一排的人高,问排列方式有多少种?

码字不易,点个赞再走吧

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

推荐阅读更多精彩内容