出栈问题的讨论
来源:互联网 发布:域名授权系统 编辑:程序博客网 时间:2024/06/08 03:40
原作者链接n个元素进栈,共有多少种出栈顺序?
支持原创 人人有责
n个元素进栈,共有多少种出栈顺序?
- 基于栈的问题分析
我们把n个元素的出栈个数的记为f(n), 那么对于1,2,3, 我们很容易得出:- f(1) = 1 //即 1
- f(2) = 2 //即 12、21
- f(3) = 5 //即 123、132、213、321、231
然后我们来考虑f(4), 我们给4个元素编号为a,b,c,d, 那么考虑:元素a只可能出现在1号位置,2号位置,3号位置和4号位置(很容易理解,一共就4个位置,比如abcd,元素a就在1号位置)。
- 分析:
- 如果元素a在1号位置,那么只可能a进栈,马上出栈,此时还剩元素b、c、d等待操作,就是子问题f(3);
- 如果元素a在2号位置,那么一定有一个元素比a先出栈,即有f(1)种可能顺序(只能是b),还剩c、d,即f(2), 根据乘法原理,一共的顺序个数为f(1) * f(2);
- 如果元素a在3号位置,那么一定有两个元素比1先出栈,即有f(2)种可能顺序(只能是b、c),还剩d,即f(1),
根据乘法原理,一共的顺序个数为f(2) * f(1); - 如果元素a在4号位置,那么一定是a先进栈,最后出栈,那么元素b、c、d的出栈顺序即是此小问题的解,即f(3);
结合所有情况,即f(4) = f(3) + f(2) * f(1) + f(1) * f(2) + f(3);
为了规整化,我们定义f(0) = 1;于是f(4)可以重新写为:
f(4) = f(0)f(3) + f(1)*f(2) + f(2) f(1) + f(3)*f(0)
然后我们推广到n,推广思路和n=4时完全一样,于是我们可以得到:
f(n) = f(0)*f(n-1) + f(1)*f(n-2) + … + f(n-1)*f(0)
即
阅读全文
0 0
- 出栈问题的讨论
- [技术讨论]讨论问题的两个基本原则
- 关于Linux线程id衍生出的讨论
- 由 HashMap 引申出的技术深度讨论
- 可能的出栈序列问题
- 关于iOS的pop出栈问题
- 关于“形式化”问题的讨论
- 外方的讨论问题方法
- 异地开发的问题讨论
- 今天开会讨论的问题!
- 邮局问题的相关讨论
- 羊车问题的讨论
- SqlDataAdapter细节问题的讨论
- CSDN两个讨论的问题
- SqlDataAdapter细节问题的讨论
- 群聊真的不适合讨论问题
- session的生命周期问题讨论!!
- jsp乱码问题的讨论
- <sqlMap embedded="iSinta.Beiwo.Infrastructure.Mappers.Member.MemberAddress.xml, iSinta.Beiwo.Inf
- EasyDSS RTMP流媒体解决方案之Windows服务安装方案
- 【回顾】深度学习之星:GAN的原理
- JAVA学习笔记-转义字符、算术运算符、类型转换
- 全国首个人工智能商业案例榜单:「AI最佳掘金案例年度评选」正式启动
- 出栈问题的讨论
- 有没有必要把机器学习算法自己实现一遍?
- React实战开发工作原理
- 实验四:时间基准电路 和 带使能的多周期计数器
- linux下的dns服务
- 架构设计主题阅读书目
- EasyDSS流媒体解决方案之多方式虚拟直播方法
- java命名规范
- Jeecg 套用框架生成的Excel导出功能