有效括号序列
题目
描述
给出一个仅包含字符’(‘,’)‘,’{‘,’}‘,’[‘和’]',的字符串,判断给出的字符串是否是合法的括号序列
括号必须以正确的顺序关闭,"()“和”()[]{}“都是合法的括号序列,但”(]“和”([)]"不合法。
数据范围:字符串长度
0≤n≤10000
要求:空间复杂度 O(n),时间复杂度 O(n)
示例1
输入:“[”
返回值:false
示例2
输入:“[]”
返回值:true
答案
java
import java.util.Stack;
/**
* @author dpx
* @date 2023/8/21 16:55
* @Version 1.0
* 有效括号序列
*/
public class SolutionKuHao {
public static void main(String[] args) {
System.out.println(SolutionKuHao.isValid("[]"));
}
public static boolean isValid(String s) {
// 辅助栈
Stack<Character> st = new Stack<>();
// 遍历字符串
for (int i = 0; i < s.length(); i++) {
// 遇到左小括号
if (s.charAt(i) == '(')
//期待遇到右小括号
st.push(')');
// 遇到左中括号
else if (s.charAt(i) == '[')
//期待遇到右中括号
st.push(']');
// 遇到左大括号
else if (s.charAt(i) == '{')
//期待遇到右大括号
st.push('}');
// 必须有左括号的情况下才能遇到右括号
else if (st.isEmpty() || st.pop() != s.charAt(i))
return false;
}
// 栈中是否还有元素
return st.isEmpty();
}
}
scala
import java.util
/**
* @author dpx
* @date 2023/8/22 9:28
* @Version 1.0
*
*/
object SolutionKuHao {
def main(args: Array[String]): Unit = {
println(isValid("["))
}
def isValid(s: String): Boolean = {
// 辅助栈
val st = new util.Stack[Character]
// 遍历字符串
for (i <- 0 until s.length) {
// 遇到左小括号
if (s.charAt(i) == '(') //期待遇到右小括号
st.push(')')
else if (s.charAt(i) == '[') //期待遇到右中括号
st.push(']')
else if (s.charAt(i) == '{') //期待遇到右大括号
st.push('}')
else if (st.isEmpty || (st.pop != s.charAt(i)))
return false
}
// 栈中是否还有元素
st.isEmpty
}
}