使用c语言编写个程序,求出任意两个数的最大公约数和最小公倍数!在线等答案……

如题所述

#include<iostream>
#include<cmath>
using namespace std;
int Gyshu(int, int);
int Gbshu(int,int);
int main(){

    int a,b;
    cout<<"请输入第一个数:"<<endl;
    cin>>a;
    cout<<"请输入第二个数:"<<endl;

    cin>>b;
 

     int c=Gyshu(a,b);
     int d=Gbshu(a,b);

     cout<<"最大公约数为:"<<c<<endl;
     cout<<"最小公倍数为:"<<d<<endl;
     return 0;
}
//最大公约数的函数
int Gyshu(int a, int b){
     int c=1;
     if(a>=b){
          for(int i=1;i<=b;i++){
                if(a%i==0&&b%i==0)c=i;
          }
     }
    else{
          for(int i=1;i<=a;i++){
               if(a%i==0&&b%i==0)c=i;
          }
    }
     return c;
}

 

//最小公倍数的函数
int Gbshu(int a, int b){
    int c=1;
    if(a>=b){
          for(int i=1;i<=b;i++){
                if(a%i==0&&b%i==0)c=i;
          }
     }
     else{
           for(int i=1;i<=a;i++){
                 if(a%i==0&&b%i==0)c=i;
           }
     }
     c=a*b/c;
     return c;
}

下面是一次执行效果图:

温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-10-18
#include <stdio.h>
int main(void)
{
int m,n,t,min,max;
printf("please input two numbers m,n:\n");
scanf("%d%d",&m,&n);
if (m < n) //保证始终m > n
t = m,m = n,n = t;
min = m % n;
if (min == 0)
min = n; //求最大公约数
max = m * n / min; //求最小公倍数
printf("min=%d\tmax=%d\n",min,max);
return 0;
}
第2个回答  2017-10-04
#include <stdio.h>
#typedef unsigned u

u x(u a,u b)
{
if (a%b)
return u(b,a%b);
else
return b;
}

u y(u a,u b)
{
return a*b/x(a,b);
}

int main(void)
{
u a,b;
scanf("%d%d",&a,&b);
printf("最大公约数是:%d\n最小公倍数是:%d",x(a,b),y(a,b));
}

本回答被网友采纳
第3个回答  2013-10-18
入门级,辗转相除法,一个算法。
相似回答