题目
类型:Math
解题思路
代码
class Solution {int n;String num;int target;List<String> ans;public List<String> addOperators(String num, int target) {this.n = num.length();this.num = num;this.target = target;this.ans = new ArrayList<String>();StringBuffer expr = new StringBuffer();backtrack(expr, 0, 0, 0);return ans;}public void backtrack(StringBuffer expr, int i, long res, long mul) {if (i == n) {if (res == target) {ans.add(expr.toString());}return;}int signIndex = expr.length();if (i > 0) {expr.append(0); // 占位,下面填充符号}long val = 0;// 枚举截取的数字长度(取多少位),注意数字可以是单个 0 但不能有前导零for (int j = i; j < n && (j == i || num.charAt(i) != '0'); ++j) {val = val * 10 + num.charAt(j) - '0';expr.append(num.charAt(j));if (i == 0) { // 表达式开头不能添加符号backtrack(expr, j + 1, val, val);} else { // 枚举符号expr.setCharAt(signIndex, '+');backtrack(expr, j + 1, res + val, val);expr.setCharAt(signIndex, '-');backtrack(expr, j + 1, res - val, -val);expr.setCharAt(signIndex, '*');backtrack(expr, j + 1, res - mul + mul * val, mul * val);}}expr.setLength(signIndex);}}
