题目
给定一个仅包含数字 0-9 的字符串 num 和一个目标值整数 target ,在 num 的数字之间添加 二元 运算符(不是一元)+、- 或 * ,返回所有能够得到目标值的表达式。
1 <= num.length <= 10
num 仅含数字
-2^31 <= target <= 2^31 - 1
思路
首先根据题目要求,可以发现,加入运算符的位置和类型是随机的,也就是说运算的数字可以是一位的, 也可以是很多位的。
对于如此多选择的情况,没有规律可循,需要采用递归枚举
- 采用枚举的策略,对所有情况均进行计算并判断
- 每一次递归时应考虑
+-*三种情况 - 注意首先确定递归终止条件,应为字符串中数字用完时。并判断运算结果是否与target一致,若一致则将这种运算记录到容器
- 运算时结果有可能超出int范围,因此需要采用
long long数据类型
代码
class Solution {
public:
vector<string> answer;
int n;
long long target_;
string num_;
vector<string> addOperators(string num, int target) {
target_ = (long long)target;
n = num.size();
num_ = num;
string str;
find_answer(str, 0, 0, 0);
return answer;
}
void find_answer(string str,int i, long long calculation, long long mul){
if(i==n){
if(calculation==target_) answer.push_back(str);
return ;
}
long long val=0;
int str_len = str.size();
if(i) str.push_back('0'); //占位
// 采用先加运算符再加数字方式
for(int j=i;j<n;j++){ //考虑一位,两位,多位数字情况
if(j>i&&num_[i]=='0') break; //防止组成的数字最高位为0
val = val*10 + num_[j]-'0';
str.push_back(num_[j]);
if(i==0) find_answer(str, j+1, val, val); //运算的首位不能是运算符
else{
str[str_len]='*';find_answer(str, j+1, calculation-mul+val*mul, val*mul);
str[str_len]='+';find_answer(str, j+1, calculation+val, val);
str[str_len]='-';find_answer(str, j+1, calculation-val, -val);
}
}
}
};
83

被折叠的 条评论
为什么被折叠?



