原题链接
- 使用栈首先将字符串的每个字符给ch当检测到左括号的时候,在deque中加入对应的右括号当左括号检测完后,若到了右括号,则若不满足 deque.isEmpty() || deque.peek() != ch 则说明此位置上的正是和s.charAt(i) 相同的符号,这时,直接跳到下一句,将deque的元素pop出。以此类推。。。。。
class Solution { public boolean isValid(String s) { Dequedeque = new linkedList<>(); char ch; for(int i = 0; i < s.length(); i++){ ch = s.charAt(i); if(ch == '(') deque.push(')'); else if(ch == '[') deque.push(']'); else if(ch == '{') deque.push('}'); else if(deque.isEmpty() || deque.peek() != ch) return false; else deque.pop(); } return deque.isEmpty(); } }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)