Class Solution

java.lang.Object
g0201_0300.s0227_basic_calculator_ii.Solution

public class Solution extends Object
227 - Basic Calculator II.<p>Medium</p> <p>Given a string <code>s</code> which represents an expression, <em>evaluate this expression and return its value</em>.</p> <p>The integer division should truncate toward zero.</p> <p>You may assume that the given expression is always valid. All intermediate results will be in the range of <code>[-2<sup>31</sup>, 2<sup>31</sup> - 1]</code>.</p> <p><strong>Note:</strong> You are not allowed to use any built-in function which evaluates strings as mathematical expressions, such as <code>eval()</code>.</p> <p><strong>Example 1:</strong></p> <p><strong>Input:</strong> s = &ldquo;3+2*2&rdquo;</p> <p><strong>Output:</strong> 7</p> <p><strong>Example 2:</strong></p> <p><strong>Input:</strong> s = &quot; 3/2 &quot;</p> <p><strong>Output:</strong> 1</p> <p><strong>Example 3:</strong></p> <p><strong>Input:</strong> s = &quot; 3+5 / 2 &quot;</p> <p><strong>Output:</strong> 5</p> <p><strong>Constraints:</strong></p> <ul> <li><code>1 <= s.length <= 3 * 10<sup>5</sup></code></li> <li><code>s</code> consists of integers and operators <code>('+', '-', '*', '/')</code> separated by some number of spaces.</li> <li><code>s</code> represents <strong>a valid expression</strong>.</li> <li>All the integers in the expression are non-negative integers in the range <code>[0, 2<sup>31</sup> - 1]</code>.</li> <li>The answer is <strong>guaranteed</strong> to fit in a <strong>32-bit integer</strong>.</li> </ul>
  • Constructor Details

    • Solution

      public Solution()
  • Method Details

    • calculate

      public int calculate(String s)