您的位置 首页 编程知识

确定括号是否平衡的算法

我开始发布一系列算法来帮助我们,我学习代码、英语并强化这一点。我希望能够帮助您并为社区做出贡献。 这个算法很容…

确定括号是否平衡的算法

我开始发布一系列算法来帮助我们,我学习代码、英语并强化这一点。我希望能够帮助您并为社区做出贡献。

这个算法很容易理解,因为你的问题很简单,但它是一个很好的例子,让我们看看如何通过简单的步骤获得解决方案。

第一步是查看问题:

“我们将利用上一课中定义的堆栈数据结构来确定一组括号是否平衡。

让我们首先了解一组平衡的括号是什么样的。

一组平衡的括号是指左括号和右括号的数量和类型匹配,并且也正确嵌套在括号串内。” (educative.io)

平衡括号示例
{ }
{ } { }
( ( { [ ] } ) )
不平衡括号示例
( ( )
{ { { ) } ]
[ ] [ ] ]

解决这个问题你的第一个想法是什么?

解决此类问题的第二步是用笔在纸上(我喜欢使用简单的图表)我们可能使用的每个变量以及我们拥有的所有数据(这类似于解决物理问题)。

显示这个新示例“}]”

数组 = [“}”, “]”]

我们需要比较字符,看例子,很明显可以用数组来比较?

def is_match(p1, p2):     if p1 == "(" and p2 == ")":         return true     elif p1 == "{" and p2 == "}":         return true     elif p1 == "[" and p2 == "]":         return true     else:         return false   def is_paren_balanced(paren_string):     s = stack()     is_balanced = true     index = 0      while index     <p>我们声明是否平衡的步骤是验证数组的数量(在 % 2 != 0 中不起作用),并发现数组中是否存在用于输入的左括号,并使用 is_match 查找右括号。 <br> 当循环结束时,声明平衡或不平衡。</p>  <p>就是这样!</p>  <p>obs:我们需要使用栈数据结构。这个方法相信你都知道。<br></p>  <pre class="brush:php;toolbar:false">class Stack():     def __init__(self):         self.items = []      def push(self, item):         self.items.append(item)                   def pop(self):         return self.items.pop()      def is_empty(self):         return self.items == []      def peek(self):         if not self.is_empty():             return self.items[-1]      def get_stack(self):         return self.items 
登录后复制

@vinycxuz

以上就是确定括号是否平衡的算法的详细内容,更多请关注php中文网其它相关文章!

本文来自网络,不代表四平甲倪网络网站制作专家立场,转载请注明出处:http://www.elephantgpt.cn/2133.html

作者: nijia

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

18844404989

在线咨询: QQ交谈

邮箱: 641522856@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部