一道大一计算机C语言编程题,急求答案,在线等,非常感谢!
展开全部
#include<stdio.h>
#include<stdlib.h>
void swap(int *num1, int *num2){
int temp;
if (*num1 > *num2){
temp = *num1;
*num1 = *num2;
*num2 = temp;
}
}
int GCD(int num1, int num2){ // 最大公约数
if (num1 == 1) return 1;
for (int i = num1; i >= 1; i--){
if (num1%i == 0 && num2%i == 0) return i;
}
return 1;
}
int LCM(int num1, int num2){ // 最小公倍数
int mult = 1, product = 0;
while (true)
{
product = mult*num2;
if (product%num1 == 0 && product%num2 == 0) return product;
++mult;
}
}
int main(){
int num1, num2;
scanf("%d %d", &num1, &num2);
swap(&num1, &num2);
printf("%d %d\n", GCD(num1, num2), LCM(num1, num2));
system("pause");
return 0;
}
更多追问追答
追问
抱歉,有编译错误
追答
你的是什么编译器?如果是VS,那么是不存在编译问题。
展开全部
#include<stdio.h>
int maxCommonDivisor(int x,int y)
{
if(x<y)
return maxCommonDivisor(y,x);
while(y)
{
int temp=x;
x=y;
y=temp%y;
}
return x;
}
int minCommenMultiple(int x,int y)
{
int temp=maxCommonDivisor(x,y);
return x/temp*y;
}
int main()
{
int first,second;
scanf(“%d%d",&first,&second);
int MAX=maxCommonDivisor,MIN=minCommenMultiple;
printf("最大公约数为%d,最小公倍数为%d",&MAX,&MIN);
}
int maxCommonDivisor(int x,int y)
{
if(x<y)
return maxCommonDivisor(y,x);
while(y)
{
int temp=x;
x=y;
y=temp%y;
}
return x;
}
int minCommenMultiple(int x,int y)
{
int temp=maxCommonDivisor(x,y);
return x/temp*y;
}
int main()
{
int first,second;
scanf(“%d%d",&first,&second);
int MAX=maxCommonDivisor,MIN=minCommenMultiple;
printf("最大公约数为%d,最小公倍数为%d",&MAX,&MIN);
}
追问
抱歉,有点错误哎
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询