在上述代码中不用栈实现
时间: 2023-12-03 16:45:43 浏览: 54
可以使用队列来实现,具体实现方法如下:
1. 创建一个空队列,命名为 queue。
2. 遍历字符串中的每个字符,如果是左括号,则将其加入到 queue 中。
3. 如果是右括号,则判断 queue 是否为空,如果是则说明当前右括号没有匹配的左括号,直接返回 False。
4. 如果 queue 不为空,则将队列中的元素出队,判断出队的元素是否为左括号的匹配项,如果不是则返回 False。
5. 如果遍历完字符串后队列中还有元素,则说明存在左括号没有匹配的右括号,返回 False。
6. 否则,返回 True。
下面是代码实现:
```python
def is_valid(s):
queue = []
left_brackets = {'(': ')', '[': ']', '{': '}'}
for c in s:
if c in left_brackets:
queue.append(c)
elif not queue or left_brackets[queue.pop()] != c:
return False
return not queue
```
这里使用了一个字典 left_brackets 来保存左括号和其对应的右括号,这样可以方便地进行匹配。在遍历字符串中的每个字符时,如果是左括号,则将其加入到队列中,如果是右括号,则从队列中取出一个元素,判断其是否为左括号的匹配项,如果不是则返回 False。最后,如果遍历完字符串后队列中还有元素,则说明存在左括号没有匹配的右括号,返回 False;否则,返回 True。
阅读全文
相关推荐
















