写两个函数,分别求两个整数的最大公约数和最小公倍数

描述

请你编写两个函数,分别用于计算给定两个正整数的最大公约数和最小公倍数。其中,最大公约数(Greatest Common Divisor,简称GCD)是指能够同时整除给定两个整数的最大正整数;而最小公倍数(Least Common Multiple,简称LCM)则是指能够同时被给定两个整数整除的最小正整数。

输入

输入包含两个正整数a和b,以空格分隔。(1 ≤ a,b ≤ 10^9)

输出

输出包含两行,每行一个整数,分别为a和b的最大公约数和最小公倍数。如果输入的不是正整数,则输出"Invalid input!"。

输入样例 1

复制代码
10 25

输出样例 1

复制代码
5
50

输入样例 2

复制代码
24 36

输出样例 2

复制代码
12
72

输入样例 3

复制代码
-6 8

输出样例 3

复制代码
Invalid input!
cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;
int GCD(int a, int b)
{
	int min = (a < b) ? a : b;
	int G=0;
	for (int i = 1; i <= min; i++)
	{
		if (a % i == 0 && b % i == 0)
			G = i;
	}
	return G;
}
int LCM(int a, int b)
{
	int L = 0;
	int max = (a > b) ? a : b;
	for (int i = max;; i++)
	{
		if (i % a == 0 && i % b == 0)
		{
			L = i;
			break;
		}
	}
	return L;
}
int main()
{
	int a, b;
	cin >> a >> b;
	if (a < 1 || b<1 || a % 1 != 0 || b % 1 != 0 || b>pow(10, 9))
	{
		cout << "Invalid input!";
	}
	else cout << GCD(a, b) << endl << LCM(a, b);
	return 0;
}
相关推荐
羑悻的小杀马特10 分钟前
C++与Redis高效交互:通过optional与迭代器玩转String/List/Set......,打造高性能存储方案!
c++·redis·交互
+++.23 分钟前
c++雪花屏(vsCode+cmake+mingw+ninja)
开发语言·c++·vscode
小年糕是糕手28 分钟前
【C++】内存管理(下)
java·c语言·开发语言·数据结构·c++·算法
一叶之秋141229 分钟前
深入剖析vector的底层实现原理
c++
艾莉丝努力练剑32 分钟前
【Linux基础开发工具 (六)】Linux中的第一个系统程序——进度条Linux:详解回车、换行与缓冲区
java·linux·运维·服务器·c++·centos
ZouZou老师34 分钟前
C++设计模式之单例模式:以小区快递柜为例
c++·单例模式·设计模式
蜗牛love天空38 分钟前
qt窗口机制和mfc窗口机制
c++
定义小花43 分钟前
c++ cmake qt
开发语言·c++·qt
草莓熊Lotso1 小时前
哈希表的两种灵魂:深入探索开放定址与链地址法的核心机密
linux·运维·数据结构·c++·人工智能·算法·哈希算法
赖small强1 小时前
【Linux C/C++开发】Linux C/C++编译参数 `-fPIC` 深度解析
linux·c语言·c++