Given a string expression of numbers and operators, return all possible results from computing all the different possible ways to group numbers and operators. You may return the answer in any order.
class Solution {
public List<Integer> diffWaysToCompute(String expression) {
List<Character> ops = new ArrayList<>();
List<Integer> numbers = new ArrayList<>();
for (int i = 0; i < expression.length(); ++i) {
char c = expression.charAt(i);
if (!isDigit(c)) {
ops.add(c);
} else {
int num = 0;
int j = i;
while (j < expression.length()) {
char cj = expression.charAt(j);
if (isDigit(cj)) {
num = num * 10 + cj - '0';
if (j == expression.length() - 1) {
numbers.add(num);
j++;
}
} else {
numbers.add(num);
break;
}
j++;
}
i = j - 1;
}
}
if (ops.isEmpty()) {
return numbers;
}
return dfs(ops, numbers, 0, numbers.size() - 1);
}
private List<Integer> dfs(List<Character> ops, List<Integer> numbers, int left, int right) {
if (left == right) {
return Arrays.asList(numbers.get(left));
}
List<Integer> ret = new ArrayList<>();
for (int i = left; i < right; ++i) {
char op = ops.get(i);
List<Integer> leftResList = dfs(ops, numbers, left, i);
List<Integer> rightResList = dfs(ops, numbers, i + 1, right);
for (int leftRes : leftResList) {
for (int rightRes : rightResList) {
ret.add(eval(op, leftRes, rightRes));
}
}
}
return ret;
}
private int eval(char op, int a, int b) {
if (op == '+') return a + b;
if (op == '-') return a - b;
if (op == '*') return a * b;
if (op == '/') return a / b;
else return Integer.MAX_VALUE;
}
private boolean isDigit(char c) {
return '0' <= c && c <= '9';
}
}