mirror of
https://github.com/youngyangyang04/leetcode-master.git
synced 2025-07-07 07:35:35 +08:00
Update
This commit is contained in:
12
README.md
12
README.md
@ -63,16 +63,20 @@
|
|||||||
|
|
||||||
持续更新中....
|
持续更新中....
|
||||||
|
|
||||||
> 笔者介绍:
|
# 关于作者
|
||||||
> ACM亚洲区域赛铜牌获得者,哈工大计算机硕士毕业后,先后在腾讯和百度工作多年,对算法和后端技术有一定的见解,利用工作之余重新刷leetcode
|
|
||||||
> 更多精彩文章持续更新,微信搜索:「代码随想录」第一时间围观,关注后回复: 「简历模板」「java」「C++」「python」「算法与数据结构」 等关键字就可以获得我多年整理出来的学习资料。
|
|
||||||
|
|
||||||
# 联系我
|
大家好,我是程序员Carl,ACM区域赛铜牌获得者,哈工大计算机硕士毕业,先后在腾讯和百度从事后端技术研发,CSDN博客专家。对算法和C++后端技术有一定的见解,利用工作之余重新刷leetcode。
|
||||||
|
|
||||||
|
我的微信:
|
||||||
|
|
||||||
<a name="微信"></a>
|
<a name="微信"></a>
|
||||||
<img src="https://img-blog.csdnimg.cn/20200712232919673.jpeg" data-img="1" width="175" height="175">
|
<img src="https://img-blog.csdnimg.cn/20200712232919673.jpeg" data-img="1" width="175" height="175">
|
||||||
|
|
||||||
# 我的公众号
|
# 我的公众号
|
||||||
|
|
||||||
|
更多精彩文章持续更新,微信搜索:「代码随想录」第一时间围观,关注后回复: 「简历模板」「java」「C++」「python」「算法与数据结构」 等关键字就可以获得我多年整理出来的学习资料。
|
||||||
|
|
||||||
<a name="公众号"></a>
|
<a name="公众号"></a>
|
||||||
|
|
||||||
<img src="https://img-blog.csdnimg.cn/20200323202104335.jpg" data-img="1" width="200" height="200">
|
<img src="https://img-blog.csdnimg.cn/20200323202104335.jpg" data-img="1" width="200" height="200">
|
||||||
|
|
||||||
|
@ -1,12 +1,33 @@
|
|||||||
|
|
||||||
## 题目地址
|
## 题目地址
|
||||||
|
|
||||||
https://leetcode-cn.com/problems/valid-parentheses/
|
https://leetcode-cn.com/problems/valid-parentheses/
|
||||||
|
|
||||||
## 思路
|
## 思路
|
||||||
|
|
||||||
括号匹配是使用栈解决的经典问题
|
括号匹配是使用栈解决的经典问题。
|
||||||
|
|
||||||
|
题意其实就像我们在写代码的过程中,要求括号的顺序是一样的,有左括号,响应的位置必须要有右括号,如果还记得编译原理的话,编译器在 词法分析的过程中处理 括号,花括号等这个符号的逻辑,也是使用了栈这种数据结构。
|
||||||
|
|
||||||
|
所以栈在计算机领域中应用是非常广泛的。 有的同学可以经常会想学的这些数据结构有什么用,也开发不了什么软件,大多数同学说的软件应该都是可视化的软件例如APP之类的,那都是非常上层的应用了,底层很多功能的实现都是基础的数据结构和算法。 这里我就不过多展开了,我们先来看题。
|
||||||
|
|
||||||
|
由于栈结构的特殊性,非常适合做对称匹配类的题目。首先我们要弄清楚,字符串里的括号不匹配有几种情况。
|
||||||
|
|
||||||
|
一些同学,在面试中看到这种题目上来就开始写代码,建议要写代码之前要分析好有哪几种不匹配的情况,如果不动手之前分析好,写出的代码也会有很多问题。 会给面试官留下不好的印象。
|
||||||
|
|
||||||
|
我们先来分析一下 这里有三种不匹配的情况,
|
||||||
|
|
||||||
|
第一种情况,字符串里左方向的括号多余了 ,所以不匹配。
|
||||||
|
第二种情况,括号没有多余,但是 括号的类型没有匹配上。
|
||||||
|
第三种情况,字符串里右方向的括号多余了,所以不匹配。
|
||||||
|
|
||||||
|
我们的代码只要覆盖了这三种不匹配的情况,基本就不会出问题,可以看出 动手之前分析好题目的重要性。
|
||||||
|
|
||||||
|
接下来我们来看一下代码。
|
||||||
|
|
||||||
## C++代码
|
## C++代码
|
||||||
|
|
||||||
|
|
||||||
```
|
```
|
||||||
class Solution {
|
class Solution {
|
||||||
public:
|
public:
|
||||||
@ -16,9 +37,12 @@ public:
|
|||||||
if (s[i] == '(') st.push(')');
|
if (s[i] == '(') st.push(')');
|
||||||
else if (s[i] == '{') st.push('}');
|
else if (s[i] == '{') st.push('}');
|
||||||
else if (s[i] == '[') st.push(']');
|
else if (s[i] == '[') st.push(']');
|
||||||
|
// 第三种情况 是遍历字符串匹配的过程中,栈已经为空了,没有匹配的字符了,说明右括号没有找到对应的左括号 return false
|
||||||
|
// 第二种情况 遍历字符串匹配的过程中,发现栈里没有我们要匹配的字符。所以return false
|
||||||
else if (st.empty() || st.top() != s[i]) return false;
|
else if (st.empty() || st.top() != s[i]) return false;
|
||||||
else st.pop(); // st.top() == s[i]
|
else st.pop(); // st.top() == s[i]
|
||||||
}
|
}
|
||||||
|
// 第一种情况 此时我们已经遍历完了字符串,但是栈不为空,说明有相应的左括号没有右括号来匹配,所以return false,否则就return true
|
||||||
return st.empty();
|
return st.empty();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
> 更多精彩文章持续更新,微信搜索「代码随想录」第一时间围观,本文[https://github.com/youngyangyang04/TechCPP](https://github.com/youngyangyang04/TechCPP) 已经收录,里面有更多干货等着你,欢迎Star!
|
||||||
|
|
||||||
## 题目地址
|
## 题目地址
|
||||||
https://leetcode-cn.com/problems/merge-two-sorted-lists/
|
https://leetcode-cn.com/problems/merge-two-sorted-lists/
|
||||||
|
@ -14,7 +14,7 @@ https://leetcode-cn.com/problems/remove-linked-list-elements/
|
|||||||
|
|
||||||
**当然如果使用java ,python的话就不用手动管理内存了。**
|
**当然如果使用java ,python的话就不用手动管理内存了。**
|
||||||
|
|
||||||
还要说明一下,就算我们使用C++来做leetcode,如果移除一个节点之后,没有手动在内存中删除这个节点,leetcode依然也是可以通过的,只不过,内存使用的空间大一些而已,但建议同学们依然要养生手动清理内存的习惯,因为在面试中 这些细节都是面试官考察的点
|
还要说明一下,就算我们使用C++来做leetcode,如果移除一个节点之后,没有手动在内存中删除这个节点,leetcode依然也是可以通过的,只不过,内存使用的空间大一些而已,但建议依然要养生手动清理内存的习惯,因为在面试中 这些细节都是面试官考察的点
|
||||||
|
|
||||||
这种情况下的移除操作,就是让节点next指针直接指向下下一个节点就可以了,
|
这种情况下的移除操作,就是让节点next指针直接指向下下一个节点就可以了,
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ public:
|
|||||||
if (st.empty() || s != st.top()) {
|
if (st.empty() || s != st.top()) {
|
||||||
st.push(s);
|
st.push(s);
|
||||||
} else {
|
} else {
|
||||||
st.pop();
|
st.pop(); // s == st.top()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
string result = "";
|
string result = "";
|
||||||
|
Reference in New Issue
Block a user