• 241. 为运算表达式设计优先级


    给你一个由数字和运算符组成的字符串 expression ,按不同优先级组合数字和运算符,计算并返回所有可能组合的结果。你可以 按任意顺序 返回答案。

    生成的测试用例满足其对应输出值符合 32 位整数范围,不同结果的数量不超过 104 。

    示例 1:

    输入:expression = "2-1-1"
    输出:[0,2]
    解释:
    ((2-1)-1) = 0 
    (2-(1-1)) = 2
    示例 2:

    输入:expression = "2*3-4*5"
    输出:[-34,-14,-10,-10,10]
    解释:
    (2*(3-(4*5))) = -34 
    ((2*3)-(4*5)) = -14 
    ((2*(3-4))*5) = -10 
    (2*((3-4)*5)) = -10 
    (((2*3)-4)*5) = 10
     

    提示:

    1 <= expression.length <= 20
    expression 由数字和算符 '+'、'-' 和 '*' 组成。
    输入表达式中的所有整数值在范围 [0, 99] 

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/different-ways-to-add-parentheses
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    以前碰到这种运算符题总是头疼,觉得思考起来好麻烦啊,运算符该怎么处理等等,

    碰巧今天每日一题就是这种题,老实讲,有些题我们为什么觉得困难,因为我们根本不愿意去思考,或者说去做,因此我们怕这种题,

    但这次这是每日一题没办法,我又必须去做了。

    确实,我看到题我能很明显的认识到,这是一道分治,递归的题目,但我也不知道该怎么处理每个分支

    所幸去看了看题解,本来以为我又要硬着头皮去思考了,没想到却意外的好理解,

    我们只用根据运算符分为左右两部分就好了

    左部分的运算值存放到左边数组,右边的存放到右边数组,

    显然递归结束的条件是一直找到不同分只下没有运算符的情况,那么这道题就比较好写了。当然这道题还有动规的方式,我也不太会哈

    1. class Solution {
    2. public:
    3. unordered_map<string,vector<int>>m;
    4. vector<int> diffWaysToCompute(string expression) {
    5. if(expression.length()==0) return vector<int>{};
    6. if(m.find(expression)!=m.end()) return m[expression];
    7. vector<int>result;
    8. int num=0;
    9. int i=0;
    10. for(i=0;i<expression.length();i++){
    11. if(expression[i]>='0'&&expression[i]<='9') num=num*10+(expression[i]-'0');
    12. else break;
    13. }
    14. if(i==expression.length()){
    15. result.push_back(num);
    16. m[expression]=result;
    17. return result;
    18. }
    19. for( i=0;i<expression.length();i++){
    20. if(!(expression[i]>='0'&&expression[i]<='9')){
    21. vector<int>result1=diffWaysToCompute(expression.substr(0,i));
    22. vector<int>result2=diffWaysToCompute(expression.substr(i+1));
    23. for(int j=0;j<result1.size();j++){
    24. for(int k=0;k<result2.size();k++){
    25. result.push_back(cacluate(result1[j],result2[k],expression[i]));
    26. }
    27. }
    28. }
    29. }
    30. return result;
    31. }
    32. int cacluate(int a,int b,char c){
    33. if(c=='+') return a+b;
    34. if(c=='-') return a-b;
    35. if(c=='*') return a*b;
    36. return -1;
    37. }
    38. };

  • 相关阅读:
    使用API有效率地管理Dynadot域名,自查账户信息
    xdebug3开启profile和trace
    VR全景展览——开启全新视界的虚拟展览体验
    大学生登记国家证书软件著作权提升就业资质
    使用 OpenGL 渲染会旋转 & 会变色的三角形(LearnOpenGL P3)
    redis集群理论和搭建
    PyTorch - autograd自动微分
    java+jsp基于ssm汽车配件管理系统-计算机毕业设计
    数据可视化在监控易中的艺术与实践
    华为机考:HJ53 杨辉三角的变形
  • 原文地址:https://blog.csdn.net/stackempty2/article/details/125553115