最大公约数

求任意两个正整数的最大公约数(GCD)。

通过从1穷举求最大公约数:

#include<iostream>
using namespace std;
int main()
{
int m,n,a;
cin>>m>>n;
if(m<n)
{
int temp=m;
m=n;
n=temp;
}
for(int i=1;i<=n;i++)
{
if(m%i==0&&n%i==0)
{
a=i;
}
}
cout<<m<<"和"<<n<<"的最大公约数为"<<a<<endl;
return 0;
}

辗转相除法:

#include<iostream>
using namespace std;

int main()
{
int m,n,b;
cin>>m>>n;
if(m<n)
{
int temp=m;
m=n;
n=temp;
}
b=m%n;
while(b!=0)
{
m=n;
n=b;
b=m%n;
}
cout<<m<<"和"<<n<<"的最大公约数为"<<n<<endl;
return 0;
}

运行结果如下:

 

posted @   为20岁努力  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示