LeetCode 20 :有效的括号
题目描述:
给定一个只包括 '('
,')'
,'{'
,'}'
,'['
,']'
的字符串 s
,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
- 每个右括号都有一个对应的相同类型的左括号。
示例 1:
输入:s = "()" 输出:true
解题思路:
分析各种情况
第一种情况:已经遍历完了字符串,但是栈不为空,说明有相应的左括号没有右括号来匹配,所以return false
第二种情况:遍历字符串匹配的过程中,发现栈里没有要匹配的字符。所以return false
第三种情况:遍历字符串匹配的过程中,栈已经为空了,没有匹配的字符了,说明右括号没有找到对应的左括号return false
那么什么时候说明左括号和右括号全都匹配了呢,就是字符串遍历完之后,栈是空的,就说明全都匹配了。
public class Solution
{
public bool IsValid(string s)
{
Stack<char> sta = new Stack<char>();
foreach (char item in s)
{
switch (item)
{
case '(':
sta.Push(')');
break;
case '[':
sta.Push(']');
break;
case '{':
sta.Push('}');
break;
case '}':
if (sta.Count==0)
{
return false;
}
else
{
if (sta.Pop()!=item)
{
return false;
};
}
break;
case ']':
if (sta.Count == 0)
{
return false;
}
else
{
if (sta.Pop() != item)
{
return false;
};
}
break;
case ')':
if (sta.Count == 0)
{
return false;
}
else
{
if (sta.Pop() != item)
{
return false;
};
}
break;
}
}
if (sta.Count>0)
{
return false;
}
else
{
return true;
}
}
}
LeetCode 1047:删除相邻重复元素
题目描述:
给出由小写字母组成的字符串 S
,重复项删除操作会选择两个相邻且相同的字母,并删除它们。
在 S 上反复执行重复项删除操作,直到无法继续删除。
在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。
示例:
输入:"abbaca" 输出:"ca" 解释: 例如,在 "abbaca" 中,我们可以删除 "bb" 由于两字母相邻且相同,这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 "aaca",其中又只有 "aa" 可以执行重复项删除操作,所以最后的字符串为 "ca"。
解题思路:
我们在删除相邻重复项的时候,其实就是要知道当前遍历的这个元素,我们在前一位是不是遍历过一样数值的元素,那么如何记录前面遍历过的元素呢?
所以就是用栈来存放,那么栈的目的,就是存放遍历过的元素,当遍历当前的这个元素的时候,去栈里看一下我们是不是遍历过相同数值的相邻元素。
public class Solution
{
public string RemoveDuplicates(string s)
{
Stack<char> sta = new Stack<char>();
foreach (char c in s)
{
if (sta.Count == 0||c!=sta.Peek())
{
sta.Push(c);
}else if (c == sta.Peek())
{
sta.Pop();
}
}
string str ="";
while (sta.Count > 0)
{
str = sta.Pop()+str;
}
return str;
}
}
LeetCode 150逆波兰表达式求值
题目描述:
给你一个字符串数组 tokens
,表示一个根据 逆波兰表示法 表示的算术表达式。
请你计算该表达式。返回一个表示表达式值的整数。
注意:
- 有效的算符为
'+'
、'-'
、'*'
和'/'
。 - 每个操作数(运算对象)都可以是一个整数或者另一个表达式。
- 两个整数之间的除法总是 向零截断 。
- 表达式中不含除零运算。
- 输入是一个根据逆波兰表示法表示的算术表达式。
- 答案及所有中间计算结果可以用 32 位 整数表示。
解题思路:
其实逆波兰表达式相当于是二叉树中的后序遍历
public class Solution
{
public int EvalRPN(string[] tokens)
{
int num;
Stack<int> stack = new Stack<int>();
foreach (string token in tokens)
{
if (int.TryParse(token,out num))
{
stack.Push(num);
}
else
{
int num1 = stack.Pop();
int num2 = stack.Pop();
switch (token)
{
case "+":
stack.Push((num2 + num1));
break;
case "-":
stack.Push((num2 - num1));
break;
case "*":
stack.Push((num2 * num1));
break;
case "/":
stack.Push((num2 / num1));
break;
default:
break;
}
}
}
return stack.Pop();
}
}