转载请注明出处:
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:
输入: "()[]{}"
输出: true
示例 3:
输入: "(]"
输出: false
示例 4:
输入: "([)]"
输出: false
示例 5:
输入: "{[]}"
输出: true
用两种方法实现:
1 import java.util.HashMap; 2 import java.util.Map; 3 import java.util.Stack; 4 5 /** 6 * 判断有效字符串 7 */ 8 public class EffectiveString { 9 /** 10 * 给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。 11 * <p> 12 * 有效字符串需满足: 13 * <p> 14 * 左括号必须用相同类型的右括号闭合。 15 * 左括号必须以正确的顺序闭合。 16 * 注意空字符串可被认为是有效字符串。 17 * 18 * @param args 19 */ 20 public static void main(String[] args) { 21 // 字符串有效时,两个特殊符号进行相互的匹配 22 boolean result1 = isValid1("()[]{}"); 23 System.out.println(result1); 24 boolean result2 = isValid2("()[]{}"); 25 System.out.println(result2); 26 } 27 28 public static boolean isValid1(String testStr) { 29 testStr = testStr.replaceAll("\\(\\)", ""); 30 testStr = testStr.replaceAll("\\[\\]", ""); 31 testStr = testStr.replaceAll("\\{\\}", ""); 32 System.out.println(testStr); 33 char[] charArr = {'(', ')', '{', '}', '[', ']'}; 34 for (int i = 0; i < charArr.length; i++) { 35 int num = testStr.indexOf(charArr[i]); 36 System.out.println(num); 37 if (num > 0) { 38 return false; 39 } 40 } 41 return true; 42 } 43 44 public static boolean isValid2(String str) { 45 Stack<Character> stack = new Stack<>(); 46 Map<Character, Character> symbolMap = new HashMap<>(); 47 symbolMap.put(']', '['); 48 symbolMap.put(')', '('); 49 symbolMap.put('}', '{'); 50 char[] charArray = str.toCharArray(); 51 for (int i = 0; i < charArray.length; i++) { 52 if (charArray[i] == '[' || charArray[i] == '(' || charArray[i] == '{') { 53 stack.push(charArray[i]); 54 } else { 55 Character value = symbolMap.get(charArray[i]); 56 if (stack.isEmpty()) { 57 return false; 58 } 59 if (value != stack.pop()) { 60 return false; 61 } 62 } 63 } 64 System.out.println(stack); 65 return stack.isEmpty(); 66 } 67 68 }
标签: 算法与数据结构