昨晚看着《堂吉诃德》入睡,前面的序和前言真的太多啦,不看又觉得不完整。杨绛和钟书都参与了翻译,钟书先生的文字好是好,但总感到有些舞文弄墨了。言归正传,看题。
1、题目描述
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/70b6c9c5a24e42f19f449961b40672b0.png)
2、逻辑分析
拿到这个题目,我的想法是,用一个哈希表存储。拿到字符串,遍历,跟后一位元素比较,相等即true,反之false。判断:字符串长度为奇数即return false。由于题目分类为简单,不存在嵌套形式,故不用考虑这一情况。还是不会写,看了题解,我的理解有些偏颇了。里面涉及到的知识是栈,利用栈先进后出的特点可以很好的解决值类型问题,找到一个相关的图,这样更好理解
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a0e34b715f33414099304b963c8050bf.png)
3、代码演示
class Solution {
public boolean isValid(String s) {
int n = s.length();
if( n % 2 ==1){
return false;
}
Map<Character , Character> paris = new HashMap<Character,Character>(){{
put(')','(');
put(']','[');
put('}','{');
}} ;
Deque<Character> stack = new LinkedList<Character>();
for(int i = 0; i < n; i++){
char ch = s.charAt(i);
if(paris.containsKey(ch)){
if(stack.isEmpty() || stack.peek() != paris.get(ch)){
return false;
}
stack.pop();
}else{
stack.push(ch);
}
}
return stack.isEmpty();
}
}
ok,看了GPT老师的解释,真的对此类型题目有更深的理解。感谢GPT的出现,真正的方便了很多人,同时我很担心,担心如今严峻的大环境下,以后会不会更内卷呢。哎,我要去打羽毛球了,下周有个小比赛,去练习一下。BYE