#include
#include
using namespace std;
int Gyshu(int, int);
int Gbshu(int,int);
int main(){
int a,b; cin>>b; int c=Gyshu(a,b); cout<<"最大公约数为:"< //最小公倍数的函数 下面是一次执行效果图:
cout<<"请输入第一个数:"<
cout<<"请输入第二个数:"<
int d=Gbshu(a,b);
}
//最大公约数的函数
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;
}
#include
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;
}
#include
#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));
}
入门级,辗转相除法,一个算法。