//给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。 // // 有效字符串需满足: // // // 左括号必须用相同类型的右括号闭合。 // 左括号必须以正确的顺序闭合。 // // // 注意空字符串可被认为是有效字符串。 // // 示例 1: // // 输入: "()" //输出: true // // // 示例 2: // // 输入: "()[]{}" //输出: true // // // 示例 3: // // 输入: "(]" //输出: false // // // 示例 4: // // 输入: "([)]" //输出: false // // // 示例 5: // // 输入: "{[]}" //输出: true // Related Topics 栈 字符串 package leetcode.editor.cn; import java.util.HashMap; import java.util.Map; import java.util.Stack; //Java:有效的括号 public class P20ValidParentheses { public static void main(String[] args) { Solution solution = new P20ValidParentheses().new Solution(); // TO TEST System.out.println(solution.isValid("()")); System.out.println(solution.isValid("()[]{}")); System.out.println(solution.isValid("(]")); System.out.println(solution.isValid("([)]")); System.out.println(solution.isValid("{[]}")); System.out.println(solution.isValid("")); } //leetcode submit region begin(Prohibit modification and deletion) class Solution { public boolean isValid(String s) { // 一开始的思路 // String s1 = "\\(\\)"; // String s2 = "\\[\\]"; // String s3 = "\\{\\}"; // int length = s.length(); // for (int i = 0; i < length; i++) { // s = s.replaceAll(s1, ""); // s = s.replaceAll(s2, ""); // s = s.replaceAll(s3, ""); // } // return "".equals(s); // 使用栈 int size = s.length(); if (size == 0) { return true; } else if (size < 2) { return false; } Stack<Character> stack = new Stack<>(); Map<Character, Character> characterMap = new HashMap<>(3); characterMap.put(')', '('); characterMap.put(']', '['); characterMap.put('}', '{'); for (int i = 0; i < size; i++) { char curChar = s.charAt(i); if (characterMap.containsKey(curChar) && !stack.empty() && stack.peek().equals(characterMap.get(curChar))) { stack.pop(); } else { stack.push(curChar); } } return stack.empty(); } } //leetcode submit region end(Prohibit modification and deletion) }
Java:有效的括号
最新推荐文章于 2024-09-28 15:50:17 发布