java.lang.Object
g0901_1000.s0921_minimum_add_to_make_parentheses_valid.Solution

public class Solution extends Object
921 - Minimum Add to Make Parentheses Valid.<p>Medium</p> <p>A parentheses string is valid if and only if:</p> <ul> <li>It is the empty string,</li> <li>It can be written as <code>AB</code> (<code>A</code> concatenated with <code>B</code>), where <code>A</code> and <code>B</code> are valid strings, or</li> <li>It can be written as <code>(A)</code>, where <code>A</code> is a valid string.</li> </ul> <p>You are given a parentheses string <code>s</code>. In one move, you can insert a parenthesis at any position of the string.</p> <ul> <li>For example, if <code>s = &quot;()))&quot;</code>, you can insert an opening parenthesis to be <code>&quot;( **( **)))&quot;</code> or a closing parenthesis to be <code>&quot;())** )** )&quot;</code>.</li> </ul> <p>Return <em>the minimum number of moves required to make</em> <code>s</code> <em>valid</em>.</p> <p><strong>Example 1:</strong></p> <p><strong>Input:</strong> s = &ldquo;())&rdquo;</p> <p><strong>Output:</strong> 1</p> <p><strong>Example 2:</strong></p> <p><strong>Input:</strong> s = &ldquo;(((&rdquo;</p> <p><strong>Output:</strong> 3</p> <p><strong>Constraints:</strong></p> <ul> <li><code>1 <= s.length <= 1000</code></li> <li><code>s[i]</code> is either <code>'('</code> or <code>')'</code>.</li> </ul>
  • Constructor Details

    • Solution

      public Solution()
  • Method Details

    • minAddToMakeValid

      public int minAddToMakeValid(String s)