LeetCode 20. 有效的括号
题目链接:20. 有效的括号
思路:栈最经典的题目了。思路想到其实就很简单了(虽然我一开始没想到)。其实仔细分析会发现不匹配的情况下无非三种。第一种 左符号多余 第二种右符号多余 第三种括号不匹配。我们依次遍历给的的括号字符串数组 当遇到左括号时将对应的右括号入栈,当遍历到与栈顶元素相同的元素时候即可出栈,代表两个括号已经进行匹配。如果栈一直为空则代表没有对应的左括号 或者 遍历到的不为左括号的右括号与括号字符串数组的值不相同则返回false 最终如果整个栈不为空的话则返回false否则返回true
具体实现:
class Solution {
public boolean isValid(String s) {
char[] chars = s.toCharArray();
Stack<Character> stack = new Stack<>();
for (int i = 0; i < s.length(); i++) {
if (chars[i]=='(') {
stack.push(')');
} else if (chars[i]=='[') {
stack.push(']');
}else if (chars[i]=='{'){
stack.push('}');
} else if (stack.isEmpty()||stack.peek()!=chars[i]) {
return false;
}else {
stack.pop();
}
}
return stack.isEmpty();
}
}
LeetCode 1047. 删除字符串中的所有相邻重复项
题目链接:1047. 删除字符串中的所有相邻重复项
思路:这道题看着难,但是想到用栈来解决就很简单。可以用栈来保存当前元素的前一个元素的值,如果当前元素的值与栈里的元素相同则就代表相邻两个元素一样,可以消掉。先依次遍历数组元素。如果遍历到元素与栈中的元素不同则该元素入栈。如果相同,让栈里的元素出栈(即消去相同的元素)因为栈里的元素是当前指向的元素前一个元素,这两个元素要是一样的,栈里的元素一出栈,则这两个一样的元素都不会在栈里存在。而指针又能指向下一个元素。继续用栈顶元素与下一个元素判断是否相同。当栈空的情况例如aabbc消去aa和bb之后栈肯定为空此时只剩下c,c直接入栈即可。这样就保证栈里的元素就是没有相邻重复的项了。
具体实现:
class Solution {
public String removeDuplicates(String s) {
char[] chars = s.toCharArray();
Stack<Character> stack = new Stack<>();
String str = "";
for (int i = 0; i < s.length(); i++) {
if (stack.isEmpty()||stack.peek()!=chars[i]){
stack.push(chars[i]);
}else {
stack.pop();
}
}
while (!stack.isEmpty()){
str = stack.pop()+str;
}
return str;
}
}
LeetCode 150. 逆波兰表达式求值
题目链接:150. 逆波兰表达式求值
思路:由于本题给出的即是逆波兰表达式,所以难度大大下降了,我一开始还要要自己写出一个中缀表达式的后缀表达式。计算机在进行计算时候都是用后缀表达式进行计算。遇到操作数即入栈,遇到运算符弹出栈顶的两个元素后一个元素 OP 前一个元素 后再放入栈中。依次直到遍历完整个后缀表达式
具体实现:
lass Solution {
public int evalRPN(String[] tokens) {
Stack<Integer> stack = new Stack();
for (int i = 0; i < tokens.length; i++) {
if(tokens[i].equals("+")||tokens[i].equals("-")||tokens[i].equals("*")||tokens[i].equals("/")){
int num1=stack.peek();
stack.pop();
int num2=stack.peek();
stack.pop();
if(tokens[i].equals("+")){
stack.push(num2+num1);
}
if(tokens[i].equals("-")){
stack.push(num2-num1);
}
if(tokens[i].equals("*")){
stack.push(num2*num1);
}
if(tokens[i].equals("/")){
stack.push(num2/num1);
}
}else {
stack.push(Integer.valueOf(tokens[i]));
}
}
return stack.pop();
}
}