鱼C论坛

 找回密码
 立即注册
查看: 1143|回复: 1

[已解决]求问! 这样子求最大公因数和最小公倍数可以吗?

[复制链接]
发表于 2020-5-21 16:37:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         long long int m, n, k, gcd;
  5.         int t;
  6.         scanf("%lld %lld", &m, &n);
  7.        
  8.         if(m < n)
  9.         {
  10.                 t = m;
  11.                 m = n;
  12.                 n = t;
  13.         }
  14.         for(k = 2; k < n; k++)
  15.         {
  16.                 if(m % k == 0 && n % k == 0)
  17.                 {
  18.                         gcd = k;//最大公因数
  19.                 }
  20.         }
  21.        
  22.         printf("%lld\n%lld\n", gcd, ((m*n)/gcd));//(m*n)/gcd最小公倍数
  23.        
  24.         return 0;
  25. }
复制代码
最佳答案
2020-5-21 16:50:14
不行,可能导致gcd根本没初始化,应该改成:
  1. #include <stdio.h>

  2. int main()
  3. {
  4.     long long int m, n, k, t, gcd = 1;
  5.     scanf_s("%lld %lld", &m, &n);

  6.     if (m < n)
  7.     {
  8.         t = m;
  9.         m = n;
  10.         n = t;
  11.     }
  12.     for (k = 2; k < n; k++)
  13.     {
  14.         if (m % k == 0 && n % k == 0)
  15.         {
  16.             gcd = k;//最大公因数
  17.         }
  18.     }

  19.     printf("%lld\n%lld\n", gcd, ((m * n) / gcd));//(m*n)/gcd最小公倍数

  20.     return 0;
  21. }
复制代码


而且你的代码效率不行,给你个快的,欧几里得法:
  1. #include<stdio.h>
  2. typedef long long ll;


  3. ll gcd(ll a, ll b)
  4. {
  5.     ll t;
  6.     while (b) {
  7.         t = a % b;
  8.         a = b;
  9.         b = t;
  10.     }
  11.     return a;
  12. }


  13. int main()
  14. {
  15.     ll a, b, t;
  16.     scanf("%lld%lld", &a, &b);
  17.     t = gcd(a, b);
  18.     printf("%lld\n%lld\n", t, a * b / t);
  19.     return 0;
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-21 16:50:14 | 显示全部楼层    本楼为最佳答案   
不行,可能导致gcd根本没初始化,应该改成:
  1. #include <stdio.h>

  2. int main()
  3. {
  4.     long long int m, n, k, t, gcd = 1;
  5.     scanf_s("%lld %lld", &m, &n);

  6.     if (m < n)
  7.     {
  8.         t = m;
  9.         m = n;
  10.         n = t;
  11.     }
  12.     for (k = 2; k < n; k++)
  13.     {
  14.         if (m % k == 0 && n % k == 0)
  15.         {
  16.             gcd = k;//最大公因数
  17.         }
  18.     }

  19.     printf("%lld\n%lld\n", gcd, ((m * n) / gcd));//(m*n)/gcd最小公倍数

  20.     return 0;
  21. }
复制代码


而且你的代码效率不行,给你个快的,欧几里得法:
  1. #include<stdio.h>
  2. typedef long long ll;


  3. ll gcd(ll a, ll b)
  4. {
  5.     ll t;
  6.     while (b) {
  7.         t = a % b;
  8.         a = b;
  9.         b = t;
  10.     }
  11.     return a;
  12. }


  13. int main()
  14. {
  15.     ll a, b, t;
  16.     scanf("%lld%lld", &a, &b);
  17.     t = gcd(a, b);
  18.     printf("%lld\n%lld\n", t, a * b / t);
  19.     return 0;
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-3 22:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表