企业面试时遇到python括号匹配笔面问题求解
问题:
左“{”,右”}"括号各N个,请打印出所有正确的组合,比如当N=3,{}{}{},{}{{}},等为正确的组合。如果写的代码是recursive,能否用iterative再写一个;反之亦然。
求好的算法描述. (不用使用循环和递归都做.一种即可.这个用递归更简单些)
py实现:
def foo(output, open, close, pairs): if open == pairs and close == pairs: print output else: if open<pairs: foo(output+'(', open+1, close, pairs) if close<open: foo(output+')', open, close+1, pairs) foo('', 0, 0, 3)
这个很容易就可以想到用回溯法来做。假设从左往右填括号。
状态包括:
(1) 填到第几个:int i
(2) 在右边最多还能填多少个 "}":int left
(3) 还剩多少个"{"可以填:int a
(4) 还剩多少个"}"可以填:int b
具体策略:
(1) 如果已经填完了,输出,返回(回溯)
(2) 如果还有"{"可以填:填进去,递归填下一个。
(3) 如果还可以填"}"并且还有"}"可以填:填进去,递归填下一个。
实现的代码附在后面。
至于转化成迭代的方式,任何递归都可以通过引入栈的方式来转化,只是写起来比较痛苦,看起来也比较痛苦就是了。
#include <stdio.h> const int maxn = 50; char x[maxn * 2 + 1]; void perm(int i, int left, int a, int b) { if (a == 0 && b == 0) { puts(x); return; } if (a > 0) { x[i] = '{'; perm(i + 1, left + 1, a - 1, b); } if (b > 0 && left > 0) { x[i] = '}'; perm(i + 1, left - 1, a, b - 1); } } int main() { int n = 4; x [n * 2] = 0; perm(0, 0, n, n); return 0; }
玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd20427.html
相关文章 Recommend
- • 如何为实时性应用存取经纬度?django mysql
- • 使用django在做添加superuser操作时报错\xBA\xA3像是乱
- • python shell脚很调用时很耗内存怎么调整
- • python高手来说说list和tuple及dict区别在哪里,什么时
- • 怎么样可以有效避免MongoDB注入时产生的一系列问
- • Flask-WTF在编辑一个记录的时候,下拉菜单如何同
- • Python UTC时区时间转换
- • 除while循环外,定时执行函数python方法有哪些
- • Python实时数据更新解决方法
- • python运行爬虫程序时间如何控制?
- • python travis测试超时源码分析
- • Flask响应内容为图片时怎么体现
您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:
必知PYTHON教程 Must Know PYTHON Tutorials
- • python 解释器
- • python idle
- • python dir函数
- • python 数据类型
- • python type函数
- • python 字符串
- • python 整型数字
- • python 列表
- • python 元组
- • python 字典
- • python 集合
- • python 变量
- • python print
- • python 函数
- • python 类定义
- • python import
- • python help
- • python open
- • python 异常处理
- • python 注释
- • python continue
- • python pass
- • python return
- • python global
- • python assert
- • python if语句
- • python break
- • python for循环
- • python while循环
- • python else/elif
- • lambda匿名函数
必知PYTHON模块 Must Know PYTHON Modules
- • os 模块
- • sys 模块
- • re 正则表达式
- • time 日期时间
- • pickle 持久化
- • random 随机
- • csv 模块
- • logging 日志
- • socket网络通信
- • json模块
- • urlparse 解析URL
- • urllib 模块
- • urllib2 模块
- • robotparser 解析
- • Cookie 模块
- • smtplib 邮件
- • Base64 编码
- • xmlrpclib客户端
- • string 文本
- • Queue 线程安全
- • math数学计算
- • linecache缓存
- • threading多线程
- • sqlite3数据库
- • gzip压缩解压
最新内容 NEWS
- • django app提供pv信息的方法是什么
- • Django项目版本升级如何操作?
- • django较多数据传递如何优雅的呈现
- • django1.7获取参数问题求助
- • Django1.7使用内置comment遇到问题
- • python mysql数据库做insert操作时报_mysql_ex
- • 关于python mysql的duplicate insert机制的疑问
- • pymongo使用insert函数批量插入被中断要怎么
- • Python程序员解决棘手问题的常用库
- • 求助关于restfull api接口几个问题
图文精华 RECOMMEND
-
django1.7获取参数问题求助
-
Python程序员解决棘手问题的常用库
-
求问str()同__str__原理上有什么不同
-
scrapy框架里面用link extractor怎么能
-
python {}.fromkeys创建字典append添加操
-
python3 类型Type str doesn't support th
热点文章 HOT
- 学习Python有什么好的书籍推荐?
- Python匿名函数 Lambda表达式作用
- Python与Java、C、Ruby、PHP等编程语言有什么
- Python 正则中文网页字符串提取问题
- 如何为实时性应用存取经纬度?django my
- 想用python做个客户端,在二维码登录这个地
- 有让IDE可识别Python函数参数类型的方法吗
- Python字符串转换成列表正则疑问