输入两个正整数,求它们的最大公约数与最小公倍数。

Problem Description

输入两个正整数,求它们的最大公约数与最小公倍数。

Input

输入两个正整数,两个整数之间用空格分开。

数据保证在 int 范围内。

Output

第一行输出最大公约数;
第二行输出最小公倍数。

答案保证在 int 范围内。

Sample Input

64 48

Sample Output

16

192

源代码

#include<stdio.h>
int main()
{
 int x,y,m,n;
 scanf("%d %d",&x,&y);
 m=x*y;
 while(y!=0)
 {
  n=x%y;
  x=y;
  y=n;
 }
 printf("%d\n",x);
 printf("%d\n",m/x);
 return 0;
}

下面是我家任先生的:

(虽然有点麻烦,但他好厉害的,原创在这里https://blog.csdn.net/weixin_44408138
#include<stdio.h>
int main()
{
 int a,b;
 int i,k;
 scanf("%d %d",&a,&b);
 if(a>0&&b>0)
 {
 if(a<b)
 {
     for(i=b-1;i>0;i--)
     {
      if(a%i==0&&b%i==0)
      {
         printf("%d\n",i); 
         break;
      }
        }
        for(k=a+1;k<2147483647;k++)
        {
         if(k%a==0&&k%b==0)
         {
             printf("%d\n",k);
             break;
         }
  }
    }
 else if(a==b)
 {
  printf("%d\n%d\n",a,a);
 }
    else
    {
     for(i=a-1;i>0;i--)
     {
      if(a%i==0&&b%i==0)
      {
         printf("%d\n",i); 
         break;
      } 
  }
  for(k=b+1;k<2147483647;k++)
  {
   if(k%a==0&&k%b==0)
   {
    printf("%d\n",k);
    break;
   }
  }
 }
    }
    else
 return 0;
 }

  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值