蓝桥杯公约数公倍数

题目标题:公约数公倍数


我们经常会用到求两个整数的最大公约数和最小公倍数的功能。


下面的程序给出了一种算法。


函数 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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值