Python实现求解括号匹配问题的方法


Posted in Python onApril 17, 2018

本文实例讲述了Python实现求解括号匹配问题的方法。分享给大家供大家参考,具体如下:

这个在本科学习数据结构的时候已经接触很多了,主流的思想是借助栈的压入、弹出来进行匹配,至于python的话可以使用列表来完成这个操作,因为列表的append方法相当于栈的push方法,列表的pop方法相当于栈的pop方法。

主要的思路:

首先设置两个列表分别存放的是各种括号的开括号和闭括号,然后遍历给定的字符串,分如下几种情况:

1.字符串首字符出现在闭括号列表中,直接结束,输出错误

2.字符串长度不为偶数,直接结束,输出错误

3.对原始字符串列表化去重,如果去重后的列表长度不为偶数直接结束,输出错误

4.遍历字符串,将属于开括号集合的括号加入到列表中,当遇上一个闭括号的时候计算该闭括号在闭括号列表中的索引与当前列表最后一个开括号在开括号列表中的索引是否一致,一致则继续,否则直接结束,输出错误

主要是在长度很大的时候可以尽快判断一些比较明显的错误的模式,节省时间,按照这个简单的思想,下面是具体的实现:

#!usr/bin/env python
#encoding:utf-8
'''''
__Author__:沂水寒城
功能:括号匹配的相关问题
'''
def bracket_mathch(one_str):
 '''''
 括号匹配
 '''
 tmp_list=[]
 open_bracket_list=['(','[','{','<','《']
 close_bracket_list=[')',']','}','>','》']
 one_str_list=list(one_str)
 length=len(one_str_list)
 set_list=list(set(one_str_list))
 num_list=[one_str_list.count(one) for one in set_list]
 if one_str[0] in close_bracket_list:
  return False
 elif length%2!=0:
  return False
 elif len(set_list)%2!=0:
  return False
 else:
  for i in range(length):
   if one_str[i] in open_bracket_list:
    tmp_list.append(one_str[i])
   elif one_str[i] in close_bracket_list:
    if close_bracket_list.index(one_str[i])==open_bracket_list.index(tmp_list[-1]):
     tmp_list.pop()
    else:
     return False
     break
 return True
if __name__ == '__main__':
 one_str_list=['({})','({[<《》>]})','[(]){}','{{{{{{','([{}])','}{[()]']
 for one_str in one_str_list:
  if bracket_mathch(one_str):
   print one_str, '正确'
  else:
   print one_str, '错误'
 tmp='{}[{()()[]<{{[[[[(())()()(){}[]{}[]()<>]]]]}}>}]'
 print bracket_mathch(tmp)

结果如下:

Python实现求解括号匹配问题的方法

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python 切片和range()用法说明
Mar 24 Python
pygame学习笔记(3):运动速率、时间、事件、文字
Apr 15 Python
python压缩文件夹内所有文件为zip文件的方法
Jun 20 Python
Python 实现数据库(SQL)更新脚本的生成方法
Jul 09 Python
python处理Excel xlrd的简单使用
Sep 12 Python
基于Python os模块常用命令介绍
Nov 03 Python
Python模糊查询本地文件夹去除文件后缀的实例(7行代码)
Nov 09 Python
python数据抓取分析的示例代码(python + mongodb)
Dec 25 Python
python3.6 tkinter实现屏保小程序
Jul 30 Python
基于python实现雪花算法过程详解
Nov 16 Python
Python函数基本使用原理详解
Mar 19 Python
移除Selenium中window.navigator.webdriver值
Jun 10 Python
django 通过ajax完成邮箱用户注册、激活账号的方法
Apr 17 #Python
对numpy中array和asarray的区别详解
Apr 17 #Python
django 开发忘记密码通过邮箱找回功能示例
Apr 17 #Python
Python实现购物车程序
Apr 16 #Python
神经网络(BP)算法Python实现及应用
Apr 16 #Python
python读取视频流提取视频帧的两种方法
Oct 22 #Python
python读取和保存视频文件
Apr 16 #Python
You might like
PHP学习 变量使用总结
2011/03/24 PHP
支持中文字母数字、自定义字体php验证码代码
2012/02/27 PHP
php实现支付宝当面付(扫码支付)功能
2018/05/30 PHP
JQuery 构建客户/服务分离的链接模型中Table中的排序分析
2010/01/22 Javascript
可在线编辑网页文字效果代码(单击)
2013/03/02 Javascript
jquery获取自定义属性(attr和prop)实例介绍
2013/04/21 Javascript
Javascript实现的常用算法(如冒泡、快速、鸽巢、奇偶等)
2014/04/29 Javascript
jQuery中大家不太了解的几个方法
2015/03/04 Javascript
js时钟翻牌效果实现代码分享
2020/07/31 Javascript
javascript倒计时效果实现
2015/11/12 Javascript
JavaScript function函数种类详解
2016/02/22 Javascript
javascript断点调试心得分享
2016/04/23 Javascript
百度多文件异步上传控件webuploader基本用法解析
2016/11/07 Javascript
vue2.0开发实践总结之入门篇
2016/12/06 Javascript
JS双击变input框批量修改内容
2016/12/12 Javascript
Es6 写的文件import 起来解决方案详解
2016/12/13 Javascript
基于JavaScript实现的折半查找算法示例
2017/04/14 Javascript
原生javascript实现的全屏滚动功能示例
2017/09/19 Javascript
vue的toast弹窗组件实例详解
2018/05/14 Javascript
实例详解ztree在vue项目中使用并且带有搜索功能
2018/08/24 Javascript
深入理解react 组件类型及使用场景
2019/03/07 Javascript
python递归删除指定目录及其所有内容的方法
2017/01/13 Python
Python面向对象之静态属性、类方法与静态方法分析
2018/08/24 Python
使用Python项目生成所有依赖包的清单方式
2020/07/13 Python
详解python实现可视化的MD5、sha256哈希加密小工具
2020/09/14 Python
Python SQLAlchemy库的使用方法
2020/10/13 Python
python使用selenium爬虫知乎的方法示例
2020/10/28 Python
python自动化办公操作PPT的实现
2021/02/05 Python
大学新生军训自我鉴定
2014/03/18 职场文书
改进作风怎么办发言材料
2014/08/17 职场文书
办公室主任岗位职责
2015/01/31 职场文书
成本会计岗位职责
2015/02/03 职场文书
建国大业观后感600字
2015/06/01 职场文书
2016年春季运动会通讯稿
2015/11/25 职场文书
2019银行员工个人工作自我鉴定
2019/06/27 职场文书
理解python中装饰器的作用
2021/07/21 Python