您的位置:首页 > 教程笔记 > 综合教程

分数加法和减法

2024-09-23 08:15:31 综合教程 159

592。分数加法和减法

难度:中等

主题:数学、字符串、模拟

给定一个表示分数加减表达式的字符串表达式,以字符串格式返回计算结果。

最终结果应该是一个不可约分数。如果您的最终结果 是整数,请将其更改为分母为 1 的分数格式。所以在这种情况下,2应该转换为2/1。

示例1:

输入:表达式 = “-1/2+1/2”

输出:“0/1”

示例2:

输入:表达式 = “-1/2+1/2+1/3”

输出:“1/3”

示例3:

输入:表达式 = “1/3-1/2”

输出:“-1/6”

限制:

输入字符串仅包含’0’到’9’、’/’、’+’和’-‘。输出也是如此。
每个分数(输入和输出)的格式为±分子/分母。如果第一个输入分数或输出为正,则将省略 ‘+’。
输入仅包含有效的不可约分数,其中每个分数的分子分母将始终在[1, 10]范围内。如果分母为 1,则意味着该分数实际上是上面定义的分数格式的整数。
给定分数的数量将在 [1, 10] 范围内。
最终结果的分子和分母保证有效并且在32位int范围内。

解决方案:

我们需要仔细解析输入字符串并对分数进行算术运算。步骤如下:

让我们用 php 实现这个解决方案:

592。分数加法和减法

<?php // Example usage
echo fractionAddition("-1/2+1/2"); // Output: "0/1"
echo "\n";
echo fractionAddition("-1/2+1/2+1/3"); // Output: "1/3"
echo "\n";
echo fractionAddition("1/3-1/2"); // Output: "-1/6"
?>

解释:

gcd 函数:计算两个数字的最大公约数,这有助于简化分数。

addfractions 函数:两个分数相加。它计算公分母,相应地调整分子,将它们相加,然后简化所得分数。

fractionaddition 函数:这是解析输入表达式的主函数,使用正则表达式提取所有分数,并使用 addfractions 函数迭代地将它们相加。

测试用例:

fractionaddition(“-1/2+1/2”) 返回 “0/1”.

fractionaddition(“-1/2+1/2+1/3”) 返回 “1/3”.

fractionaddition(“1/3-1/2”) 返回 “-1/6”.

此解决方案处理所有必需的操作,并为每个给定表达式返回正确的输出。

联系链接

如果您发现本系列有帮助,请考虑在 github 上给

存储库 一颗星,或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

领英

github

相关推荐

  • js中正则表达式怎么用

    js中正则表达式怎么用

    JavaScript 正则表达式:入门指南何谓正则表达式?正则表达式(regex)是用于在文本中查找、匹配或替换特定模式的强大工具。它们广泛应用于各种编程任务,例如验证输入、处理字符串和解析数据。Ja

    前端笔记 2024-06-22 12:21:45 36
  • vue中的插值表达式的用法

    vue中的插值表达式的用法

    Vue 中插值表达式的用法插值表达式是 Vue 中用于将数据绑定到 HTML 模板的一种语法结构。它允许开发者直接在 HTML 模板中访问 Vue 实例中的数据,从而使数据动态地显示在页面上。用法插值

    前端笔记 2024-05-03 17:28:27 186
  • C++ 函数模板详解:探索表达式模板的强大之处

    C++ 函数模板详解:探索表达式模板的强大之处

    表达式模板是特殊的函数模板,可在编译时求值表达式。它们提供以下优点:编译时计算:避免运行时开销。类型安全:由编译器验证表达式的类型。可重用:可在不同类型上使用通用代码。C++ 函数模板详解:探索表达式

    综合教程 2024-04-29 16:05:34 73
  • C++ 函数指针与 lambda 表达式:揭晓回调魔法

    C++ 函数指针与 lambda 表达式:揭晓回调魔法

    函数指针和 lambda 表达式均允许将函数作为参数传递给回调函数。函数指针保存指向函数地址的变量,而 lambda 表达式是匿名函数对象,可即时定义函数。通过实战案例,我们演示了使用函数指针和 la

    综合教程 2024-04-29 16:03:14 208
  • golang有lambda表达式吗

    golang有lambda表达式吗

    Go 中的 Lambda 表达式Go 语言中没有明确的 lambda 表达式语法,但它提供了匿名函数,其行为类似于 lambda 表达式。匿名函数匿名函数是一种没有名称的函数,可以直接嵌入到代码中。它

    综合教程 2024-04-24 19:35:04 53