鱼C论坛

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

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

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

最佳答案

查看完整内容

这个方法叫辗除法 是数学原理
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-4-11 22:44:18 | 显示全部楼层
#include <stdio.h>
int main()
{
  int a,b,num1,num2,temp;
  printf("please input two numbers:\n");
  scanf("%d,%d",&num1,&num2);
  if(num1<num2)/*交换两个数,使大数放在num1上*/
  {
    temp=num1;
    num1=num2;
    num2=temp;
  }
  a=num1;b=num2;
  while(b!=0)/*利用辗除法,直到b为0为止*/
  {
    temp=a%b;
    a=b;
    b=temp;
  }
  printf("gongyueshu:%d\n",a);
  printf("gongbeishu:%d\n",num1*num2/a);
  return 0;
}
这个方法叫辗除法 是数学原理
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

最小公约数是1没有最大公倍数(无穷大)
#include <stdio.h>
void main()
{
 int x,y,tempGY,tempGB,GY,GB;
 printf("输入两个正整数(用空格分开),求这两个正整数的最小公倍数和最大公约数:\n");
 scanf("%d%d",&x,&y);
 
 for(int i=1;i<=(x<y?x:y);i++)
 {
  if(x%i==0 && y%i==0)
   GY=i;
 }
 
 tempGB=x*y;
 for(i=tempGB;i>=(x<y?y:x);i--)
 {
  if(i%x==0 && i%y==0)
   GB=i;
 }
 printf("最大公约数是%d,最小公倍数是%d\n",GY,GB);
 getchar();
 
}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-26 00:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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