鱼C论坛

 找回密码
 立即注册
查看: 3118|回复: 2

求解!!!C语言最大/最小公约数,最大/最小公倍数

[复制链接]
发表于 2014-4-11 22:44:17 | 显示全部楼层 |阅读模式
10鱼币
以前会的,最近稀里糊涂就忘记了.而且老师又马上就讲到这里了,希望各位帮写一下,不胜感激.希望说明一下算法原理,谢啦!~

最佳答案

查看完整内容

这个方法叫辗除法 是数学原理
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-4-11 22:44:18 | 显示全部楼层
  1. #include <stdio.h>
  2. int main()
  3. {
  4.   int a,b,num1,num2,temp;
  5.   printf("please input two numbers:\n");
  6.   scanf("%d,%d",&num1,&num2);
  7.   if(num1<num2)/*交换两个数,使大数放在num1上*/
  8.   {
  9.     temp=num1;
  10.     num1=num2;
  11.     num2=temp;
  12.   }
  13.   a=num1;b=num2;
  14.   while(b!=0)/*利用辗除法,直到b为0为止*/
  15.   {
  16.     temp=a%b;
  17.     a=b;
  18.     b=temp;
  19.   }
  20.   printf("gongyueshu:%d\n",a);
  21.   printf("gongbeishu:%d\n",num1*num2/a);
  22.   return 0;
  23. }
复制代码
这个方法叫辗除法 是数学原理
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-4-11 22:58:33 | 显示全部楼层
本帖最后由 向往青莲 于 2014-4-11 23:00 编辑

最小公约数是1没有最大公倍数(无穷大)

  1. #include <stdio.h>
  2. void main()
  3. {
  4. int x,y,tempGY,tempGB,GY,GB;
  5. printf("输入两个正整数(用空格分开),求这两个正整数的最小公倍数和最大公约数:\n");
  6. scanf("%d%d",&x,&y);

  7. for(int i=1;i<=(x<y?x:y);i++)
  8. {
  9.   if(x%i==0 && y%i==0)
  10.    GY=i;
  11. }

  12. tempGB=x*y;
  13. for(i=tempGB;i>=(x<y?y:x);i--)
  14. {
  15.   if(i%x==0 && i%y==0)
  16.    GB=i;
  17. }
  18. printf("最大公约数是%d,最小公倍数是%d\n",GY,GB);
  19. getchar();

  20. }
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-9 12:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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