给表达式添加运算符Java
文章发布较早,内容可能过时,阅读注意甄别。
# 题目
给定一个仅包含数字 0-9 的字符串 num 和一个目标值整数 target ,在 num 的数字之间添加 二元 运算符(不是一元)+、- 或 * ,返回 所有 能够得到 target 的表达式。
注意,返回表达式中的操作数 不应该 包含前导零。
示例 1:
输入: num = "123", target = 6
输出: ["1+2+3", "1*2*3"]
解释: “1*2*3” 和 “1+2+3” 的值都是6。
示例 2:
输入: num = "232", target = 8
输出: ["2*3+2", "2+3*2"]
解释: “2*3+2” 和 “2+3*2” 的值都是8。
示例 3:
输入: num = "3456237490", target = 9191
输出: []
解释: 表达式 “3456237490” 无法得到 9191 。
提示:
- 1 <= num.length <= 10
- num 仅含数字
- -231 <= target <= 231 - 1
# 思路
回溯
# 解法
class Solution {
List<String> res = new ArrayList<>();
StringBuilder sb = new StringBuilder();
public List<String> addOperators(String num, int target) {
if (num.length() == 0) return res;
backTracking(num, 0, 0, 0, target);
return res;
}
public void backTracking(String num, int start, long pre, long sum, int target) {
if (start == num.length()) {
if (sum == target) res.add(new StringBuilder(sb).toString());
return;
}
for (int i = start; i < num.length(); i++) {
if (num.charAt(start) == '0' && i != start) break;
String str = num.substring(start, i + 1);
long val = Long.valueOf(str);
if (start == 0) {
sb.append(str);
backTracking(num, i + 1, val, sum + val, target);
sb.delete(sb.length() - str.length(), sb.length());
} else {
sb.append("+").append(str);
backTracking(num, i + 1, val, sum + val, target);
sb.delete(sb.length() - str.length() - 1, sb.length());
sb.append("-").append(str);
backTracking(num, i + 1, -val, sum - val, target);
sb.delete(sb.length() - str.length() - 1, sb.length());
sb.append("*").append(str);
backTracking(num, i + 1, val * pre, sum - pre + val * pre, target);
sb.delete(sb.length() - str.length() - 1, sb.length());
}
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# 总结
- 分析出几种情况,然后分别对各个情况实现