241. Different Ways to Add Parentheses

package LeetCode_241

import java.util.*
import kotlin.collections.ArrayList

/**
 * 241. Different Ways to Add Parentheses
 * https://leetcode.com/problems/different-ways-to-add-parentheses/description/
 * Given a string of numbers and operators, return all possible results from computing all the different possible ways to group numbers and operators.
 * The valid operators are +, - and *.
 *
Example 1:
Input: "2-1-1"
Output: [0, 2]
Explanation:
((2-1)-1) = 0
(2-(1-1)) = 2

Example 2:
Input: expression = "2*3-4*5"
Output: [-34,-14,-10,-10,10]
Explanation:
(2*(3-(4*5))) = -34
((2*3)-(4*5)) = -14
((2*(3-4))*5) = -10
(2*((3-4)*5)) = -10
(((2*3)-4)*5) = 10

Constraints:
1. 1 <= expression.length <= 20
2. expression consists of digits and the operator '+', '-', and '*'.
 * */
class Solution {
    /*
    * solution:DFS, Memorization with map, split each char to check it digit or symbol and calculate value with operations from left to right
    * Time:O(n*2^n), Space:O(2^n)
    * */
    fun diffWaysToCompute(expression: String): List<Int> {
        val map = HashMap<String, List<Int>>()
        return dfs(expression, map)
    }

    private fun dfs(expression: String, map: HashMap<String, List<Int>>): List<Int> {
        if (map.containsKey(expression)){
            return map.getOrDefault(expression, ArrayList<Int>())
        }
        val values = ArrayList<Int>()
        if (!hasOperations(expression)) {
            //just put digit in values
            values.add(expression.toInt())
        } else {
            for (i in expression.indices) {
                val c = expression[i]
                if (!c.isDigit()) {
                    val left = dfs(expression.substring(0, i), map)
                    //substring form current i to the end
                    val right = dfs(expression.substring(i + 1), map)
                    //check each digit from left sub list and right sub list
                    for (l in left) {
                        for (r in right) {
                            when (c) {
                                '+' -> values.add(l + r)
                                '-' -> values.add(l - r)
                                '*' -> values.add(l * r)
                            }
                        }
                    }
                }
            }
        }
        //save into map for next level
        map.put(expression, values)
        return values
    }

    private fun hasOperations(expression: String):Boolean{
        for (c in expression){
            if (c=='+' || c=='-' || c=='*'){
                return true
            }
        }
        return false
    }
}

 

posted @ 2021-09-01 00:05  johnny_zhao  阅读(20)  评论(0编辑  收藏  举报