LeetCode之Valid Parentheses

举报
chenyu 发表于 2021/07/27 01:40:56 2021/07/27
【摘要】 1、题目 Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the input string is valid. The brackets must close i...

1、题目

Given a string containing just the characters '('')''{''}''[' and ']', determine if the input string is valid.

The brackets must close in the correct order, "()" and "()[]{}" are all valid but "(]" and "([)]" are not.

 

 


2、思路

用stack来实现,左边的进栈,如果是右边的出栈,发现没有或者不匹配就返回false
 
 
 
 
 
 

3、代码实现


   
  1. public class Solution {
  2. public boolean isValid(String s) {
  3. if (s == null || s.length() == 0) {
  4. return false;
  5. }
  6. char chars[] = s.toCharArray();
  7. Stack<Character> stack = new Stack<Character>();
  8. for (int i = 0; i < chars.length; ++i) {
  9. if (chars[i] == '(' || chars[i] == '{' || chars[i] == '[') {
  10. stack.add(chars[i]);
  11. } else {
  12. if (!stack.isEmpty()) {
  13. Character value = stack.pop();
  14. if (chars[i] == ')') {
  15. if (value != '(')
  16. return false;
  17. }
  18. if (chars[i] == '}') {
  19. if (value != '{')
  20. return false;
  21. }
  22. if (chars[i] == ']') {
  23. if (value != '[')
  24. return false;
  25. }
  26. } else {
  27. return false;
  28. }
  29. }
  30. }
  31. return stack.isEmpty();
  32. }
  33. }

 
 

 

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/77104503

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。