c++,求最大公约数最小公倍数

#include<iostream>
using namespace std;
int main()
{

	int num1, num2; 
	cin >> num1 >> num2;    // 输入两个数的值
	int Max_g, Min_g;       // 定义最大公约数和最小公倍数
	int a = num1, b = num2; // 备份输入的两个数,用来求最小公倍数

        // 辗转相模法求最大公约数
	int temp; //定义一个临时变量
	while (num1%num2 != 0)
	{
		temp = num1%num2;
		num1 = num2;
		num2 = temp;
	}
	Max_g = num2;

	// 辗转相减法求最大公约数
	/*while(num1!=num2)
	{ 
		if (num1 > num2)
			num1 = num1 - num2;
		else
			num2 = num2 - num1;
	}
	Max_g = num2; */
	

	//利用最大公约数求最小公倍数

	Min_g = a*b / Max_g;

	cout << "最大公约数:" << Max_g << endl;
	cout << "最小公倍数:" << Min_g << endl;
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值