最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。
这里只说辗转相除法
辗转相除法:辗转相除法是求两个自然数的最大公约数的一种方法,也叫欧几里得算法。
例如,求(319,377):
∵ 319÷377=0(余319)
∴(319,377)=(377,319);
∵ 377÷319=1(余58)
∴(377,319)=(319,58);
∵ 319÷58=5(余29)
∴ (319,58)=(58,29);
∵ 58÷29=2(余0)
∴ (58,29)= 29;
∴ (319,377)=29。
#include<iostream>
using namespace std;
int main()
{
int x,y,t;
cin>>x>>y;
swap(x,y);
while(y)
{
t=y;
y=x%y;
x=t;
}
cout<<x<<endl;
}
欧几里得模板
#include<iostream>
using namespace std;
int gcd(int x,int y)
{
if(x<y)
swap(x,y);
return y==0?x:gcd(y,x%y);
}
int main()
{
int x,y;
cin>>x>>y;
cout<<gcd(x,y)<<endl;
}