CodeDance2023 2024-02-23 19:23 采纳率: 96%
浏览 6
已结题

欧拉函数求互质数的细节问题


#include <iostream>
using namespace std;
int main()
{
    int n, res;
    while (cin >> n, n != 0)
    {
        res = n;  //一开始设置为输入的数字,后面慢慢除
        for (int i = 2; i * i <= n; ++i)      //试除因子
        {
            if (n % i == 0)
            {
                res = res / i * (i - 1);    //根据欧拉函数算,累乘上(1 - 1/pi)的化简形式
                while (n % i == 0)
                {
                    n = n / i;       //n要除干净这个因子
                }
            }
        }
        if (n > 1)          //循环完成后n还是大于1,说明还有一个因子,就是此时的n
        {
            res = res / n * (n - 1);     //根据欧拉函数算,继续累乘上(1 - 1/n)的化简形式
        }
        cout << res << endl;
    }
    return 0;
}

为什么将这个res = res / i * (i - 1);改成 res = res * (i - 1)/ i,virtual jugde 就说答案错误,这两个不是一样的吗?
为什么oj说答案错误?必须要先整除再乘吗

  • 写回答

1条回答 默认 最新

  • GISer Liu 2024-02-23 19:23
    关注

    该回答引用自GPT-3.5,由博主GISer Liu编写:

    在你的代码中,将 res = res / i * (i - 1); 修改为 res = res * (i - 1) / i;
    确实会导致结果不同,因为这两种写法在计算机中的运算顺序是不同的。
    在第一种写法中,先计算了 res / i,然后再乘以 (i - 1)。而在第二种写法中,先计算了 ``` res * (i

      1. ,然后再除以 i 。 这两种写法在数学上确实是等价的,但在计算机中由于浮点数精度问题可能导致结果不同。特别是在整数运算中,除法可能产生向下取整的效果,导致最终结果不同。 因此,为了确保结果的准确性,建议保留原来的写法 res = res / i * (i - 1); ```。

    如果该回答解决了您的问题,请采纳!如果没有,请参考以下方案进行修订

    用户答题指南

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月4日
  • 已采纳回答 2月25日
  • 创建了问题 2月23日

悬赏问题

  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题
  • ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含