LC282. 给表达式添加运算符

题目

给定一个仅包含数字 0-9 的字符串 num 和一个目标值整数 target ,在 num 的数字之间添加 二元 运算符(不是一元)+、- 或 * ,返回所有能够得到目标值的表达式。

1 <= num.length <= 10
num 仅含数字
-2^31 <= target <= 2^31 - 1

思路

首先根据题目要求,可以发现,加入运算符的位置和类型是随机的,也就是说运算的数字可以是一位的, 也可以是很多位的。
对于如此多选择的情况,没有规律可循,需要采用递归枚举

  1. 采用枚举的策略,对所有情况均进行计算并判断
  2. 每一次递归时应考虑+-*三种情况
  3. 注意首先确定递归终止条件,应为字符串中数字用完时。并判断运算结果是否与target一致,若一致则将这种运算记录到容器
  4. 运算时结果有可能超出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);
            } 
        }
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值