Leetcode•Jun 08, 2026
Valid Parenthesis String
Hazrat Ali
Leetcode
The following rules define a valid string:
- 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"".
Example 1:
Input: s = "()" Output: true
Example 2:
Input: s = "(*)" Output: true
Example 3:
Input: s = "(*))" Output: true
Solution
/**
* @param {string} s
* @return {boolean}
*/
var checkValidString = function(s) {
let low = 0;
let high = 0;
for (const ch of s) {
if (ch === '(') {
low++;
high++;
} else if (ch === ')') {
low--;
high--;
} else {
low--;
high++;
}
if (high < 0) return false;
if (low < 0) low = 0;
}
return low === 0;
};