• 640. 求解方程(JavaScript)


    题目描述

    在这里插入图片描述

    思路

    顺序遍历字符串,遍历过程直接算出x的系数(coefficient),以及另外一个常数(value)
    借用=切割两个字符串,整体分成左右两部分处理,因为符号不一样。
    字符串处理的时候有以下情况:

    • 只有x:更新系数coefficient
    • “+”或者“-”:更新符号标识符curSign
    • 数字
      • 全是数字:更新value,遇到+或-时进行下一步处理
      • 数字后面有x:更新系数coefficient,接着进行下一步处理

    补充

    • 全局变量置零,要不然后台多个连续用例过不了
    • Number( ),将参数转化成数字
    • isNaN( ), 不是数字则返回 true,是数字类型则返回 false

    AC代码

    在这里插入图片描述

    全注释

    /**
     * @param {string} equation
     * @return {string}
     */
    let coefficient=0;//x的系数
    let value =0;
    
    var solveEquation = function(equation) {
        //全局变量置零,要不然后台多个连续用例过不了
        coefficient=0;
        value = 0;
        //等号左边一组,等号右边一组
        let array = equation.split("=");
        parse(array[0],1);
        parse(array[1],-1);
        if(coefficient==0)
            return value==0?"Infinite solutions":"No solution";
        else
            return "x="+(-value/coefficient);
    };
    
    var parse= function (str,sign){
        i=0;
        curSign=1;
        while(i<str.length){
            //处理单个x
            if(str[i]=='x'){
                coefficient+=sign*curSign;
                i++;
            }
            //处理+号,改变下一次运算的正负标识符curSign
            else if(str[i]=='+'){
                curSign=1; 
                i++;
            }
            //处理-号,改变下一次运算的正负标识符curSign
            else if(str[i]=='-'){
                curSign=-1; 
                i++;
            } 
            //处理数字
            else{
                let num=0;
                //循环遍历所有数字并且存储
                while(i<str.length&&!isNaN(Number(str[i]))){
                    num=num*10+Number(str[i])
                    i++;
                }
                //当数字后面是x时
                if(str[i]=='x'){
                    coefficient+=num*curSign*sign;
                    i++;
                }
                //当数字后面时+或者-时
                else
                    value+=num*curSign*sign;
            }
            
        }
    }
    
    • 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
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
  • 相关阅读:
    Qt5.9.1-下载安装环境搭建——HelloWorld
    注册中心Eureka与Nacos
    MySQL8.0与MySQL5.7差异分析
    Object.create()
    性能测试场景的设计方法
    C++ static小结
    ai-agent1-概念
    【排序 - 堆排序】
    RocketMQ-RocketMQ部署(Linux、docker)
    SpringBoot+Vue项目篮球竞赛预约平台
  • 原文地址:https://blog.csdn.net/weixin_51914472/article/details/126274203