用java编程:给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 每个右括号都有一个对应的相同类型的左括号。
时间: 2024-09-14 08:03:48 浏览: 48
在Java编程中,判断给定的字符串是否为有效的括号组合可以通过使用栈(Stack)数据结构来实现。基本思想是遍历字符串中的每个字符,遇到左括号就将其入栈,遇到右括号就尝试匹配栈顶的左括号,如果匹配成功则将栈顶元素出栈,否则返回无效。最后,如果栈为空,则说明字符串是有效的。
以下是一个简单的实现步骤:
1. 创建一个栈实例。
2. 遍历字符串中的每一个字符。
3. 如果字符是左括号,将其入栈。
4. 如果字符是右括号,检查栈是否为空,以及栈顶元素是否与当前右括号匹配:
- 如果栈为空或者不匹配,说明字符串无效,返回false。
- 如果匹配,栈顶元素出栈。
5. 遍历完成后,检查栈是否为空:
- 如果栈为空,则说明所有括号都正确匹配,返回true。
- 如果栈不为空,则说明有未匹配的左括号,返回false。
下面是一个Java代码示例:
```java
import java.util.Stack;
public class ValidParentheses {
public static boolean isValid(String s) {
Stack<Character> stack = new Stack<>();
for (char c : s.toCharArray()) {
if (c == '(' || c == '{' || c == '[') {
stack.push(c);
} else {
if (stack.isEmpty()) return false;
char topChar = stack.pop();
if ((c == ')' && topChar != '(') ||
(c == '}' && topChar != '{') ||
(c == ']' && topChar != '[')) {
return false;
}
}
}
return stack.isEmpty();
}
public static void main(String[] args) {
String input = "{[]}()";
System.out.println(isValid(input)); // 输出:true
}
}
```
阅读全文