题目标题:公约数公倍数
我们经常会用到求两个整数的最大公约数和最小公倍数的功能。
下面的程序给出了一种算法。
函数 myfunc 接受两个正整数a, b
经过运算后打印出 它们的最大公约数和最小公倍数。
此时,调用 myfunc(15, 20)
将会输出:
5
60
// 交换数值
void swap(int *a, int *b)
{
int temp;
temp = *a;
*a = *b;
*b = temp;
}
void myfunc(int a, int b)
{
int m, n, r;
if (a<b) swap(&a, &b);
m = a;n = b;r = a%b;
while (r != 0)
{
a = b;b = r;
r = a%b;
}
printf("%d\n", b); // 最大公约数
printf("%d\n", ); // 最小公倍数
}
请分析代码逻辑,并推测划线处的代码,通过网页提交。
注意:仅把缺少的代码作为答案,千万不要填写多余的代码、符号或说明文字!!
我们经常会用到求两个整数的最大公约数和最小公倍数的功能。
下面的程序给出了一种算法。
函数 myfunc 接受两个正整数a, b
经过运算后打印出 它们的最大公约数和最小公倍数。
此时,调用 myfunc(15, 20)
将会输出:
5
60
// 交换数值
void swap(int *a, int *b)
{
int temp;
temp = *a;
*a = *b;
*b = temp;
}
void myfunc(int a, int b)
{
int m, n, r;
if (a<b) swap(&a, &b);
m = a;n = b;r = a%b;
while (r != 0)
{
a = b;b = r;
r = a%b;
}
printf("%d\n", b); // 最大公约数
printf("%d\n", ); // 最小公倍数
}
请分析代码逻辑,并推测划线处的代码,通过网页提交。
注意:仅把缺少的代码作为答案,千万不要填写多余的代码、符号或说明文字!!
#include<stdio.h>
void swap(int *a, int *b)
{
int temp;
temp = *a;
*a = *b; //这个是交换他们的地址,当然这个也可以用值交换!
*b = temp;
}
void myfunc(int a, int b)
{
int m, n, r;
if (a<b) swap(&a, &b);
m = a;n = b;r = a%b;
while (r != 0) //当然这个也可以用循环的方法!
{
a = b;b = r; //这个是转转相除法!
r = a%b;
}
printf("%d\n", b); // 最大公约数
printf("%d\n", m*n/b); // 最小公倍数
}
int main()
{
myfunc(15, 20);
return 0;
}