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℃
    本文版权归作者和博客园共有,欢迎转载,转载时保留原作者和文章地址即可。
  • 相关阅读:
    如何开发一款浏览器[转]
    粒子滤波实现物体跟踪的算法原理:
    Canny边缘检测(转)
    [转载] 图像处理常用边缘检测算子总结
    [转载]Sobel边缘检测
    Android读取手机联系人信息
    【Android】动态注册广播接收器
    Android对话框的生成
    C语言基础丨(六)程序结构——顺序结构【1】
    C语言丨指针基础知识详解
  • 原文地址:https://www.cnblogs.com/maggieq8324/p/14875537.html
Copyright © 2011-2022 走看看