zoukankan      html  css  js  c++  java
  • LeetCode

    前言

    /**
     * @Description LeetCode 20. 有效的括号
     * 给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。
     * 有效字符串需满足:
     * 左括号必须用相同类型的右括号闭合。
     * 左括号必须以正确的顺序闭合。
     *
     * 来源:力扣(LeetCode)
     * 链接:https://leetcode-cn.com/problems/valid-parentheses
     */
    

    具体实现

    • 实现类
    public class Solution {
        /**
         * 有效的括号 - 自定义栈
         * @param s
         * @return
         */
        public static boolean isValidCustom(String s) {
            ArrayStack<Character> arrayStack = new ArrayStack<>();
    
            for (int i = 0; i < s.length(); i++) {
                char c = s.charAt(i);
    
                if (c == '(' || c == '[' || c == '{') {
                    arrayStack.push(c);
                } else {
                    if (arrayStack.isEmpty()) {
                        return false;
                    }
    
                    char d = arrayStack.pop();
                    if (c == ')' && d != '(') {
                        return false;
                    } else if (c == ']' && d != '[') {
                        return false;
                    } else if (c == '}' && d != '{') {
                        return false;
                    }
                }
            }
    
            return arrayStack.isEmpty();
    
        }
    
        /**
         * 有效的括号 - java Stack
         * @param s
         * @return
         */
        public static boolean isValid(String s) {
            java.util.Stack<Character> characters = new java.util.Stack<>();
    
            for (int i = 0; i < s.length(); i++) {
                char c = s.charAt(i);
    
                if (c == '(' || c == '[' || c == '{') {
                    characters.push(c);
                } else {
                    if (characters.isEmpty()) {
                        return false;
                    }
    
                    char d = characters.pop();
                    if (c == ')' && d != '(') {
                        return false;
                    } else if (c == ']' && d != '[') {
                        return false;
                    } else if (c == '}' && d != '{') {
                        return false;
                    }
                }
    
            }
    
            return characters.isEmpty();
        }
    
        public static void main(String[] args) {
            System.out.println(isValidCustom("()"));
            System.out.println(isValid("("));
        }
    }
    
    - End -
    一个努力中的公众号
    关注一下吧
    以上为本篇文章的主要内容,希望大家多提意见,如果喜欢记得点个推荐哦
    作者:95.8℃
    本文版权归作者和博客园共有,欢迎转载,转载时保留原作者和文章地址即可。
  • 相关阅读:
    Nginx 解决WebApi跨域二次请求以及Vue单页面问题
    微信小程序部署问题总结
    Webapi文档描述-swagger优化
    [AOP系列]Autofac+Castle实现AOP日志
    WebApi Ajax 跨域请求解决方法(CORS实现)
    MSDTC启用——分布式事务
    [钉钉通知系列]Jenkins发布后自动通知
    [AOP系列]Autofac+Castle实现AOP事务
    [钉钉通知系列]SVN提交后自动推送消息到钉钉群
    Vue H5 History 部署IIS上404问题
  • 原文地址:https://www.cnblogs.com/maggieq8324/p/14875537.html
Copyright © 2011-2022 走看看