[leetcode]分治算法之Different Ways to Add Parenthese

本文探讨了分治算法的概念,强调了递归在解决此类问题中的应用,并以LeetCode上的Different Ways to Add Parentheses为例进行讲解。除了详细解答题目,还介绍了如何通过递归对数字进行两两组合,并分享了一种原始但有效的解决方案。同时,提到了string.substr()函数的使用技巧。
摘要由CSDN通过智能技术生成

分治算法之Different Ways to Add Parentheses

分治的思考

分治:把问题分为k份,然后再将这k份连起来。

方法:一般用递归来做。

注意:处理递归终止条件,即问题规模最小的情况

典型例题:归并排序、快速排序

其他的学习

string.substr(pos,len) 的用法

题干

leetcode入口

答案

很慢的一种答案,但是毕竟是自己想出来的。

先把数字和字符作为int从字符分离出来,存到一个vector<int>里面,注意运算符存的是位置

然后用递归对返回的vector<int>中的数字两两组合

class Solution {
public:
    vector<int> diffWaysToCompute(string input) {
        
        vector<int> res;
        vector<int> v; //存储字符和数字
        
        res.clear();
        v.clear();
        
        string a="";
        for(int i=0;i<input.size();i++){
            
            if(input[i]!='+' && input[i]!='-' && input[i]!='*'){
                a+=input[i];    
            }
            else{
                v.push_back(stoi(a));
                a="";
                v.push_back(i); //把位置加进去
            }
        }
        
        v.push_back(stoi(a));
        if(v.size()==1) return v;
        
        for(int i=1;i<v.size();i=i+2){
            int index=v[i];
            char op=input[index];
            
            vector<int> left=diffWaysToCompute(input.substr(0,index));
            vector<int> right=diffWaysToCompute(input.substr(index+1));
            
            if(op=='+'){
                for(int i=0;i<left.size();i++){
                    for(int j=0;j<right.size();j++){
                        res.push_back(left[i]+right[j]);
                    }
                }
            }
            else if(op=='-'){
                for(int i=0;i<left.size();i++){
                    for(int j=0;j<right.size();j++){
                        res.push_back(left[i]-right[j]);
                    }
                }
            }
            else{
                for(int i=0;i<left.size();i++){
                    for(int j=0;j<right.size();j++){
                        res.push_back(left[i]*right[j]);
                    }
                }
            }
        }
        
        return res;
    }
};

改进(网上代码):

class Solution {
public:
    vector<int> diffWaysToCompute(string input) {
        vector<int> res;
        for (int i = 0; i < input.size(); ++i) {
            if (input[i] == '+' || input[i] == '-' || input[i] == '*') {
                vector<int> left = diffWaysToCompute(input.substr(0, i));
                vector<int> right = diffWaysToCompute(input.substr(i + 1));
                for (int j = 0; j < left.size(); ++j) {
                    for (int k = 0; k < right.size(); ++k) {
                        if (input[i] == '+') res.push_back(left[j] + right[k]);
                        else if (input[i] == '-') res.push_back(left[j] - right[k]);
                        else res.push_back(left[j] * right[k]);
                    }
                }
            }
        }
        if (res.empty()) res.push_back(stoi(input));
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值