Class Solution

  • All Implemented Interfaces:

    
    public final class Solution
    
                        

    678 - Valid Parenthesis String.

    Medium

    Given a string s containing only three types of characters: '(', ')' and '*', return true if s is valid.

    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

    Constraints:

    • 1 <= s.length <= 100

    • s[i] is '(', ')' or '*'.

    • Nested Class Summary

      Nested Classes 
      Modifier and Type Class Description
    • Field Summary

      Fields 
      Modifier and Type Field Description
    • Constructor Summary

      Constructors 
      Constructor Description
      Solution()
    • Enum Constant Summary

      Enum Constants 
      Enum Constant Description
    • Method Summary

      Modifier and Type Method Description
      final Boolean checkValidString(String s)
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait