牛客网 编程题——C++求最小公倍数 《完整代码加分析》

本文详细解析了求解两个正整数最小公倍数的算法,通过求最大公约数的方法来高效计算最小公倍数。文章提供了完整的程序代码及运行结果,适合编程初学者理解和实践。

一,题目描述

正整数A和正整数B 的最小公倍数是指 能被A和B整除的最小的正整数值,设计一个算法,求输入A和B的最小公倍数。

输入描述:

输入两个正整数A和B。

输出描述:

输出A和B的最小公倍数。

示例1

输入

5 7

输出

35

二,程序分析

1.最小公倍数 = 两数之积除以最大公约数

2.即a与b的最大公约数,可以转化为a、b之间的余数为两者之间最小的数之间的公约数。所以对于输入的两个数进行连续求余,直到余数为0,求余的分母即为结果。

3.所以根据这个原理,解题思路还是比较清晰的,编程过程也是可以的

三,程序代码

#include<iostream>

using namespace std;

int gcb(int a, int b)
{
	int r;
	while (r = a%b)
	{
		a = b;
		b = r;
	}
	return b;
}
int main()
{
	int a, b;
	while (cin >> a >> b)
	{
		//用两者的乘积除余最大公约数
		cout << a*b / gcb(a, b) << endl;
	}

	return 0;
}

四,程序运行结果
在这里插入图片描述
感觉不错的话,关注一个再走啊!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值