-
-
Notifications
You must be signed in to change notification settings - Fork 109
/
Stacks:BalancedBrackets.java
37 lines (30 loc) 路 1.07 KB
/
Stacks:BalancedBrackets.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import java.io.*;
import java.util.*;
public class BalancedBrackets {
public static boolean isBalanced(String expression) {
Stack<Character> stack = new Stack<>();
for (char curr : expression.toCharArray()) {
if (curr == '{' || curr == '(' || curr == '[')
stack.push(curr);
else {
if (stack.isEmpty())
return false;
char last = (char) stack.pop();
if ((curr == '}' && last != '{') || (curr == ']' && last != '[') || (curr == ')' && last != '('))
return false;
}
}
return stack.isEmpty();
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int t = Integer.parseInt(sc.nextLine());
StringBuilder sb = new StringBuilder();
for (int i = 0; i < t; i++) {
String expression = sc.nextLine();
sb.append(isBalanced(expression) ? "YES\n" : "NO\n");
}
System.out.println(sb.toString());
sc.close();
}
}