LeetCode:有效的括号

简介: LeetCode:有效的括号

题目链接:20. 有效的括号 - 力扣(Leetcode)


还是老套路二话不说,先上代码:

 

typedef char STDataType;
typedef struct Stack
{
  STDataType* a;
  int top;
  int capacity;
}ST;
// 初始化栈
void STInit(ST* pst);
// 销毁栈
void STDestroy(ST* pst);
// 添加数据
void STPush(ST* pst, STDataType x);
// 删除数据
void STPop(ST* pst);
// 弹出数据
STDataType STTop(ST* pst);
// 判断是否为空
bool STEmpty(ST* pst);
// 判断大小
int STSize(ST* pst);
// 初始化栈
void STInit(ST* pst)
{
  assert(pst);
  pst->a = NULL;
  pst->top = 0;
  pst->capacity = 0;
}
// 销毁栈
void STDestroy(ST* pst)
{
  assert(pst);
  free(pst->a);
  pst->a = NULL;
  pst->top = 0;
  pst->capacity = 0;
}
// 添加数据
void STPush(ST* pst, STDataType x)
{
  if (pst->capacity == pst->top)
  {
    int newcapacity = (pst->capacity == 0 ? 4 : pst->capacity * 2);
    STDataType* tmp = (STDataType*)realloc(pst->a, newcapacity * sizeof(STDataType));
    if (tmp == NULL)
    {
      perror("realloc fail");
      return;
    }
    pst->a = tmp;
    pst->capacity = newcapacity;
  }
  pst->a[pst->top] = x;
  pst->top++;
}
// 删除数据
void STPop(ST* pst)
{
  assert(pst);
  assert(!(STEmpty(pst)));
  pst->top--;
}
// 弹出数据
STDataType STTop(ST* pst)
{
  assert(pst);
  assert(!(STEmpty(pst)));
  return pst->a[pst->top - 1];
}
// 判断是否为空
bool STEmpty(ST* pst)
{
  assert(pst);
  return pst->top == 0;
}
// 判断大小
int STSize(ST* pst)
{
  assert(pst);
  return pst->top;
}
bool isValid(char* s) {
  ST st;
  STInit(&st);
  while (*s)
  {
    // 左括号入栈
    if (*s == '(' || *s == '{' || *s == '[')
    {
      STPush(&st, *s);
    }
    // 右括号出栈匹配
    else
    {
      if (STEmpty(&st))
      {
        STDestroy(&st);
        return false;
      }
      else
      {
        char tmp = STTop(&st);
        STPop(&st);
        if (*s == ']' && tmp != '[' || *s == ')' && tmp != '(' || *s == '}' && tmp != '{')
        {
          STDestroy(&st);
          return false;
        }
      }
    }
    ++s;
  }
  bool ret = STEmpty(&st);
  STDestroy(&st);
  return ret;
}

1b4b18e2b766be8dfa47f4f379053e2c_cb838c690a2344d1bc225b355cdcceb6.png

  过啦!!!!!!


题目思路:


    该题比较简单,是对栈特性很好的应用,具体操作如下:

    循环遍历String中的字符,逐个取到每个括号,如果该括号是:

       1. 左括号,直接入栈

       2. 右括号,与栈顶的左括号进行匹配,如果不匹配直接返回false

          否则继续循环

    循环结束后,如果栈空则匹配,否则左括号比右括号多肯定不匹配


我们需要注意的细节


1.最后返回true时,栈必须为空,才能保证括号的匹配成功了的。

2.第一个字符如果是右括号,那么肯定就不匹配了,直接返回false。  


目录
相关文章
|
6月前
|
存储 C语言 索引
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
环形链表、环形链表 II、有效的括号​​​​​​​【LeetCode刷题日志】
|
9天前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
1月前
|
算法 C++
Leetcode第二十二题(括号生成)
这篇文章讨论了如何使用递归算法解决LeetCode第22题“括号生成”的问题,提供了两种C++的实现方法,目的是生成所有有效的括号组合。
15 0
Leetcode第二十二题(括号生成)
|
1月前
|
存储 C++ 容器
Leetcode第二十题(有效的括号)
这篇文章介绍了如何使用栈来解决LeetCode第20题“有效的括号”问题,提供了两种方法:数组栈和容器栈,以及相应的C++代码实现。
16 0
|
3月前
|
算法
LeetCode第22题括号生成
该文章介绍了 LeetCode 第 22 题括号生成的解法,通过回溯算法生成所有可能的括号组合,在递归过程中根据左右括号数量的条件进行剪枝,从而得到有效的括号组合。
LeetCode第22题括号生成
|
3月前
|
存储 算法
LeetCode第20题有效的括号
该文章介绍了 LeetCode 第 20 题有效的括号的解法,通过分析有效括号的特征,使用栈结构存储括号关系,判断遇到右边括号时栈顶是否有匹配的左边括号,从而解决问题,同时总结了栈的先进后出结构可用于解决有规律的符号匹配问题。
LeetCode第20题有效的括号
|
3月前
|
算法 Python
【Leetcode刷题Python】括号匹配问题
一种解决括号匹配问题的Python实现方法,通过计算给定括号串的所有子串的最长合法括号子序列长度之和来确定权值。
23 0
|
3月前
|
机器学习/深度学习 Python
【Leetcode刷题Python】22. 括号生成
本文介绍了了LeetCode题目22的两种Python编程解决方案,题目要求生成所有可能的且有效的括号组合,包括暴力求解和回溯方法。
25 0
|
3月前
|
Python
【Leetcode刷题Python】20. 有效的括号
LeetCode上题目“20. 有效的括号”的Python解决方案,使用栈数据结构来验证括号序列的有效性。具体实现中,会在栈中预先放置一个特殊字符以避免在弹出操作时出现空栈错误,并通过匹配左右括号来判断括号序列是否有效。
42 0
|
5月前
|
算法 Java C语言
【经典算法】LeetCode 20:有效的括号(Java/C/Python3实现含注释说明,Easy)
【经典算法】LeetCode 20:有效的括号(Java/C/Python3实现含注释说明,Easy)
41 1