Given a string containing only three types of characters: '(', ')' and '*', write a function to check whether this string is valid. We define the validity of a string by these rules:
- Any left parenthesis
'('
must have a corresponding right parenthesis')'
. - Any right parenthesis
')'
must have a corresponding left parenthesis'('
. - Left parenthesis
'('
must go before the corresponding right parenthesis')'
. '*'
could be treated as a single right parenthesis')'
or a single left parenthesis'('
or an empty string.- An empty string is also valid.
Example 1:
Input: "()" Output: True
Example 2:
Input: "(*)" Output: True
Example 3:
Input: "(*))" Output: True
Note:
- The string size will be in the range [1, 100].
给定一个仅包含三种类型的字符的字符串:'(',')'和'*',编写一个函数来检查此字符串是否有效。 我们通过以下规则定义字符串的有效性:
- 任何左括号'('必须有相应的右括号')'。
- 任何右括号')'必须具有相应的左括号'('。
- 左括号'('必须在相应的右括号之前'')'。
- '*'可以被视为单个右括号')'或单个左括号'('或一个空字符串。
- 空字符串也是有效的。
注意:
- 字符串长度的范围是 [1, 100].
这题我也不明白他想做什么。我这边使用了min和max分别表示右括号最小和最大出现的次数。只要一次循环,最后比较min是否为0就行了,min大于0就是右括号还需要再写min次,才能使字符串有效
class Solution {
public:
bool checkValidString(string s) {
int min = 0, max = 0;
for(int i = 0; i < s.length(); i++){
if(s[i] == '('){
min++;
max++;
}
else if(s[i] == ')'){
min--;
max--;
}
else if(s[i] == '*'){
min--;
max++;
}
if(min < 0){
min = 0;
}
if(max < 0){
return false;
}
}
if(min == 0)
return true;
else
return false;
}
};