Valid Parenthesis String
Question:
思路
这个题呢, 我们首先把它当作没有*的题型.
没有*的话就简单很多了。我们只需要判断opening bracket的数量和closing bracket的数量是否一致.
balabala
加上*的题型就是多了一点儿条件, 我们在没有*的题型上面做更改.
无非就是*可以变成opening bracket/closing bracket or empty.
那就是相当于每次多了三种可能
那么我们就可以扩展一下上面那个题型的思路.
我们每次定义一个最大opening bracket的值,再定义一个最小opening bracket的值
就是说.我们可以假设* = “(”, 也可以假设* = “)”
等于"(“的情况就是 最大opening bracket增加
等于”)"的情况就是 最小opening bracket数量.
用一个leetcode的人讲解的图解释一下
我们可以看到cmin 和 cmax是我们分别定义的最大opening bracket 和 最小opening bracket的值.
一旦我们的cmin < 0 了 就说明*变成")“的可能不可行, 那就把cmin 变回0。
但是一但cmax 都 < 0 了就说明真的我们的”)" 过多了。就要return false了。
一旦cmin 最后最后 > 0, 那就说明即使把所有的* 都当作")", 也还是不够close. 那就invalid了.
class Solution {
public boolean checkValidString(String s) {
int cmin = 0, cmax = 0; // open parentheses count in range [cmin, cmax]
for (char c : s.toCharArray()) {
if (c == '(') {
cmax++;
cmin++;
} else if (c == ')') {
cmax--;
cmin--;
} else if (c == '*') {
cmax++; // if `*` become `(` then openCount++
cmin--; // if `*` become `)` then openCount--
// if `*` become `` then nothing happens
// So openCount will be in new range [cmin-1, cmax+1]
}
if (cmax < 0) return false; // Currently, don't have enough open parentheses to match close parentheses-> Invalid
// For example: ())(
cmin = Math.max(cmin, 0); // It's invalid if open parentheses count < 0 that's why cmin can't be negative
}
return cmin == 0; // Return true if can found `openCount == 0` in range [cmin, cmax]
}
}