一道大一计算机C语言编程题,急求答案,在线等,非常感谢!

 我来答
仙戈雅3n
推荐于2016-05-12 · TA获得超过5790个赞
知道大有可为答主
回答量:2398
采纳率:75%
帮助的人:901万
展开全部
#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,那么是不存在编译问题。
qscgyujn
2014-12-11 · 超过12用户采纳过TA的回答
知道答主
回答量:31
采纳率:0%
帮助的人:13万
展开全部
#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);
}
追问
抱歉,有点错误哎
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式