• 入门力扣自学笔记119 C++ (题目编号640)


    640. 求解方程

    题目:

    求解一个给定的方程,将x以字符串 "x=#value" 的形式返回。该方程仅包含 '+' , '-' 操作,变量 x 和其对应系数。

    如果方程没有解,请返回 "No solution" 。如果方程有无限解,则返回 “Infinite solutions” 。

    题目保证,如果方程中只有一个解,则 'x' 的值是一个整数。


    示例 1:

    输入: equation = "x+5-3+x=6+x-2"
    输出: "x=2"


    示例 2:

    输入: equation = "x=x"
    输出: "Infinite solutions"


    示例 3:

    输入: equation = "2x=x"
    输出: "x=0"


    提示:

    3 <= equation.length <= 1000
    equation 只有一个 '='.
    equation 方程由整数组成,其绝对值在 [0, 100] 范围内,不含前导零和变量 'x' 。


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


    思路:

    这个方法的核心工作就是统计出左右两侧的x的数量以及化简后常数项的大小,设它们为x_count,num
    以"x+5-3+x=6+x-2"为例,左右端都化简完可以得到"2x+2=x+4",即对于左端来说x_count = 2,num = 2;对于右端来说x_count = 1,num=4。
    由于两侧的化简方法是相同的所以我们把它提取成同一个函数,用一个vector作为返回值存储x_count,num。最终的x_count = left_x_count - right_x_count,
    num = right_num - left_num。
    那么x = num/x_count,在进行这步计算之前要判断x_count =0 的情况:当num=0则对应Infinite solutions”;当num!=0则对应“No solution”。
    因为本道题只有加减法,因此我们只需根据读取到的+/-来改变当前的sign = 1/-1即可,数字或者x_count更新时注意乘以当前的sign。
    本道题的一些cornercase:
    1.在读取数字时需要考虑多位数的情况,当我们终止数字读取时一定是遇见了非数字项:x/+/-,或者数字在结尾。前三种情况对数字处理的方式也有所不同:当数字后面接上x时,我们要更新x_count;当数字后面是+/-时,直接计算求和即可,注意要乘以sign。若表达式以数字作为结尾,这种情况我们还需要单独考虑。
    2.答案中给了一个特别不合规矩的cornercase "0x=0",针对这种情况我们只能特殊问题特殊处理了,读取到了x前面的数字为y,则x_count += y*sign。但这样会使“x+5 = 3”这种x前面没有数字的情况变成新的cornercase,因此我们可以把这个进行特殊化处理,而把前一种情况泛化处理即可。


    作者:darwin_tao
    链接:https://leetcode.cn/problems/solve-the-equation/solution/zuo-you-yi-qi-hua-jian-gou-zao-fu-zhu-ha-xo1q/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


    代码:

    1. class Solution {
    2. public:
    3. /* 化简函数:可以将包含x的字符串表达式化简成x_count*x+num的形式*/
    4. vector<int> simplify(string s){
    5. vector<int> result(2,0);//result[0]存储x_count,result[1]存储num
    6. int sign = 1;//默认符号为1
    7. int x_count = 0;//初始化为0
    8. int num = 0;//工具
    9. int sum= 0;//最终常数项
    10. for(int i =0;isize();i++){
    11. char c = s[i];
    12. if(c>='0'&&c<='9'){//读取数字
    13. num = num*10+c-'0';
    14. }
    15. else{
    16. if(c=='x') {
    17. //对应cornercase(2)
    18. if(i>0&&(s[i-1]=='+'||s[i-1]=='-')||i==0) x_count += sign;
    19. else x_count += sign*num;
    20. num = 0;//停止读数后为了下一次使用方便要清0
    21. }
    22. else {
    23. sum += num*sign;//累加sum
    24. num = 0;//清零
    25. if(c=='+') sign = 1;
    26. if(c=='-') sign = -1;
    27. }
    28. }
    29. }
    30. if(num !=0 ){//表达式可能以数字结尾,以上终止条件无法包含这种情况
    31. sum += num*sign;
    32. }
    33. result[0] = x_count;
    34. result[1] = sum;
    35. return result;
    36. }
    37. string solveEquation(string equation) {
    38. int i = equation.size();
    39. if(i==0) return "No solution"; i--;
    40. while(equation[i]!= '=') i--;//找到‘=’将字符串分成左右两部分
    41. string s_left = equation.substr(0,i);
    42. string s_right = equation.substr(i+1,equation.size()-i-1);
    43. //deal with left
    44. vector<int> left = simplify(s_left);
    45. //deal with right
    46. vector<int> right = simplify(s_right);
    47. //organize the result
    48. int x_count = left[0]-right[0];
    49. int num = right[1]-left[1];
    50. if(x_count==0&&num==0) return "Infinite solutions";
    51. if(x_count==0&&num!=0) return "No solution";
    52. string s = to_string(num/x_count);
    53. return "x="+s;
    54. }
    55. };


     

  • 相关阅读:
    Spring的事件通知
    [深度学习]--分类问题的排查错误的流程
    SpringBoot整合oceanbase,实现oracle无缝切换到oceanbase
    GFD563A102 3BHE046836R0102 只读存储器本质上是非易失性的
    如何用Python机器学习、深度学习提升气象、海洋、水文领域实践能力!!!
    论文推荐:当自监督遇到主动学习
    2022年最新辽宁建筑八大员(标准员)考试试题及答案
    Web前端小组考核总结
    Autosar诊断实战系列03-22服务读取DID数据的几种接口类型区别详解
    Java后台解决request请求体不能重复读取+解决XSS漏洞问题
  • 原文地址:https://blog.csdn.net/DK_Sorhic/article/details/126262627