题目

类型:Math

image.png

解题思路

image.png

代码

  1. class Solution {
  2. int n;
  3. String num;
  4. int target;
  5. List<String> ans;
  6. public List<String> addOperators(String num, int target) {
  7. this.n = num.length();
  8. this.num = num;
  9. this.target = target;
  10. this.ans = new ArrayList<String>();
  11. StringBuffer expr = new StringBuffer();
  12. backtrack(expr, 0, 0, 0);
  13. return ans;
  14. }
  15. public void backtrack(StringBuffer expr, int i, long res, long mul) {
  16. if (i == n) {
  17. if (res == target) {
  18. ans.add(expr.toString());
  19. }
  20. return;
  21. }
  22. int signIndex = expr.length();
  23. if (i > 0) {
  24. expr.append(0); // 占位,下面填充符号
  25. }
  26. long val = 0;
  27. // 枚举截取的数字长度(取多少位),注意数字可以是单个 0 但不能有前导零
  28. for (int j = i; j < n && (j == i || num.charAt(i) != '0'); ++j) {
  29. val = val * 10 + num.charAt(j) - '0';
  30. expr.append(num.charAt(j));
  31. if (i == 0) { // 表达式开头不能添加符号
  32. backtrack(expr, j + 1, val, val);
  33. } else { // 枚举符号
  34. expr.setCharAt(signIndex, '+');
  35. backtrack(expr, j + 1, res + val, val);
  36. expr.setCharAt(signIndex, '-');
  37. backtrack(expr, j + 1, res - val, -val);
  38. expr.setCharAt(signIndex, '*');
  39. backtrack(expr, j + 1, res - mul + mul * val, mul * val);
  40. }
  41. }
  42. expr.setLength(signIndex);
  43. }
  44. }