2022-07-10 08:29:59 +08:00
|
|
|
# Leetcode Valid-Parentheses
|
2022-06-16 14:55:49 +08:00
|
|
|
|
|
|
|
#### 2022-06-16 14:50
|
|
|
|
|
|
|
|
> ##### Data structures:
|
|
|
|
> #DS #stack
|
|
|
|
> ##### Difficulty:
|
|
|
|
> #coding_problem #difficulty-easy
|
|
|
|
> ##### Additional tags:
|
|
|
|
> #leetcode
|
|
|
|
> ##### Revisions:
|
2022-07-03 09:58:52 +08:00
|
|
|
> 1st revision: 2022-07-03 optimize code
|
2022-06-16 14:55:49 +08:00
|
|
|
|
|
|
|
##### Related topics:
|
|
|
|
```expander
|
|
|
|
tag:#stack
|
|
|
|
```
|
|
|
|
|
2022-07-05 10:48:41 +08:00
|
|
|
- [[Leetcode Implement-Queue-Using-Stacks]]
|
2022-06-16 14:55:49 +08:00
|
|
|
|
|
|
|
|
|
|
|
##### Links:
|
2022-06-16 15:25:12 +08:00
|
|
|
- [Link to problem](https://leetcode.com/problems/valid-parentheses/)
|
2022-06-16 14:55:49 +08:00
|
|
|
___
|
|
|
|
### Problem
|
2022-06-16 15:25:12 +08:00
|
|
|
Given a string `s` containing just the characters `'('`, `')'`, `'{'`, `'}'`, `'['` and `']'`, determine if the input string is valid.
|
|
|
|
|
|
|
|
An input string is valid if:
|
|
|
|
|
|
|
|
1. Open brackets must be closed by the same type of brackets.
|
|
|
|
2. Open brackets must be closed in the correct order.
|
2022-06-16 14:55:49 +08:00
|
|
|
|
|
|
|
#### Examples
|
2022-06-16 15:25:12 +08:00
|
|
|
**Example 1:**
|
|
|
|
|
|
|
|
```markdown
|
|
|
|
**Input:** s = "()"
|
|
|
|
**Output:** true
|
|
|
|
```
|
|
|
|
|
|
|
|
**Example 2:**
|
|
|
|
|
|
|
|
```markdown
|
|
|
|
**Input:** s = "()[]{}"
|
|
|
|
**Output:** true
|
|
|
|
```
|
|
|
|
|
|
|
|
**Example 3:**
|
2022-06-16 14:55:49 +08:00
|
|
|
|
2022-06-16 15:25:12 +08:00
|
|
|
```markdown
|
|
|
|
**Input:** s = "(]"
|
|
|
|
**Output:** false
|
|
|
|
```
|
2022-06-16 14:55:49 +08:00
|
|
|
#### Constraints
|
2022-06-16 15:25:12 +08:00
|
|
|
- `1 <= s.length <= 104`
|
|
|
|
- `s` consists of parentheses only `'()[]{}'`.
|
2022-06-16 14:55:49 +08:00
|
|
|
|
|
|
|
### Thoughts
|
|
|
|
|
2022-06-16 15:25:12 +08:00
|
|
|
Basic stack usage.
|
|
|
|
Can be implemented using std_stack or stc_vector.
|
|
|
|
obviously i should use std_stack.
|
2022-06-16 14:55:49 +08:00
|
|
|
### Solution
|
2022-07-03 09:58:52 +08:00
|
|
|
1st revision: optimized code
|
|
|
|
```cpp
|
|
|
|
class Solution {
|
|
|
|
public:
|
|
|
|
bool isValid(string s) {
|
|
|
|
stack<char> st;
|
|
|
|
|
|
|
|
char pairs[3][2] = {'(', ')', '{', '}', '[', ']'};
|
|
|
|
const int pairSize = 3;
|
|
|
|
|
|
|
|
for (char c : s) {
|
|
|
|
for (int i = 0; i < pairSize; i++) {
|
|
|
|
if (pairs[i][0] == c) {
|
|
|
|
// {([
|
|
|
|
st.push(c);
|
|
|
|
} else if (pairs[i][1] == c) {
|
|
|
|
// ]})
|
|
|
|
if (st.empty()) {
|
|
|
|
// empty
|
|
|
|
return false;
|
|
|
|
} else if (st.top() != pairs[i][0]) {
|
|
|
|
// mismatch
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
st.pop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return st.empty();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
```
|
2022-06-16 15:25:12 +08:00
|
|
|
|
|
|
|
```cpp
|
|
|
|
class Solution {
|
|
|
|
public:
|
|
|
|
bool isValid(string s) {
|
|
|
|
vector<char> stack;
|
|
|
|
vector<vector<char>> pairs = {{'(', ')'}, {'{', '}'}, {'[', ']'}};
|
|
|
|
|
|
|
|
int loc;
|
|
|
|
const int size = pairs.size();
|
|
|
|
for (char c : s) {
|
|
|
|
|
|
|
|
for (loc = 0; loc < size; loc++) {
|
|
|
|
if (c == pairs[loc][1]) {
|
|
|
|
if (stack.empty()) {
|
|
|
|
// if there is no {([ before
|
|
|
|
printf("No {([ before.\n");
|
|
|
|
return false;
|
|
|
|
} else if (stack.back() == pairs[loc][0]) {
|
|
|
|
stack.pop_back();
|
|
|
|
} else {
|
|
|
|
// parens mismatch
|
|
|
|
printf("parens mismatch: %c %c\n", stack.back(), pairs[loc][0]);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else if (c == pairs[loc][0]) {
|
|
|
|
stack.push_back(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (stack.empty()) {
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-07-03 09:58:52 +08:00
|
|
|
```
|
|
|
|
|