括号匹配问题是用“栈”这种数据结构来解决的一道典型问题,本文由此引申,谈到了Leetcode中多道与此有关的问题或变种题,这也是笔试、面试中十分常见的一种题目类型。本文主要以LeetCode中的若干具体问题为例,通过对解题思路的讲解,讨论此类问题的解法(具体解答使用C++或Python3实现)。更多有趣的算法问题、更多有用的数据结构知识,你还可以参考《算法之美——隐匿在数据结构背后的原理》一书(本书繁体中文版已授权博硕文化出版集团在中国台湾地区发行)。
1. 括号匹配问题
程序设计语言是用来编写程序的工具。计算机硬件可以识别的语言是机器语言,通常人们编写的计算机程序所用的高级语言必须被转换成机器语言才可以被计算机理解。将高级语言编写的源程序翻译为等价的计算机可以理解的程序的过程称为编译,而实现编译功能的程序称为编译程序。编译程序是计算机中非常复杂的一种系统程序。在通常的集成开发环境中都,编译程序都是最精细、最复杂、也最重要的部分。
一个典型的编译程序一般都含有八个部分,即词法分析、语法分析、语义分析、中间代码生成、代码优化程序、目标代码生成、错误检查和处理以及各种信息表格的管理。它们相互协同配合完成编译任务。其中在语法分析阶段,语法分析程序以词法分析程序所输出的用内部编码格式表示的单词序列作为输入,其任务是分析源程序的结构,判断它是否为相应程序设计语言中的一个合法程序,即判定程