2021/04/20 求最大公约数C语言

1.暴力法:遍历公约数求出最大者 

// 方法1:遍历法
// 参考:https://blog.csdn.net/qq_41575507/article/details/90752742
int max_ComNum_method1(int a, int b)
{
	int min;
	int result;
	int i = 1;
	min = a <= b ? a : b;
	while(i < min)
	{
		if(a%i==0 && b%i==0)
		{
			result = i;
		}
		i++;
	}
	return i;
}

2.辗转相除法

例子:64%12=4;12%4=1;4%1=0,最大公约数是4 

// 方法2:转转相除法
int max_ComNum_method2(int a, int b)
{
	int rest;
	while (b > 0)
	{
		rest = a % b;
		a = b;
		b = rest;
	}
	return a;
}

3.更相减损术

 例子:64-12=52;52-12=40;40-12=28;28-12=16;16-12=4,最大公约数是4 

// 方法3:更相减损术
int max_ComNum_method3(int a, int b)
{
	int dec;
	while (b > 0)
	{
		dec = abs(a - b);
		a = b;
		b = dec;
	}
	return a;
}

4.辗转相除的递归解法 


// 方法4:递归
int max_ComNum_method4(int a, int b)
{
	if (b == 0) return a;
	return max_ComNum_method4(b, a % b); // 递归
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vicssic

与你一起成长

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值