C语言:利用自定义函数,求两个数的最大公约数。

程序分析:

1. 在主函数中,输入要求最大公约数的两个数 a , b,然后进入子程序中;

2. 在子程序中先判断输进来的两个数的大小,若 b < a 则借助中间变量交换他俩的值,这一步是为了保证 a 是两个值中的最小值。若没有这一步程序就存在 bug,因为当 a > b 时程序就会出错。

3. 接着将最小值 a 作为除数,若 b 可以整除 a 则说明 a 就是最大的公约数;若不能整除,则 a 的值依次减小1,然后继续做除数看能否被整除。

注:此处为什么要选择 a 依次递减1,而不是递增?这是因为题目要求的是最大的公约数,如果递增就会存在问题,即有时两个数存在不止一个的公约数,但有的公约数并不是最大的公约数,所以此处选择让 a 递减就可找到最大的公约数。

#include<stdio.h>
int Greatest_Common_Divisor(int a,int b)
{
	int i;
	if (b < a)
	{
		i = b;
		b = a;
		a = i;
	}
	if (b % a == 0)
	{
		printf("最大公约数为:");
		return a;
	}
	printf("\n");
	if (b % a != 0)
	{
		for (i = a; i > 0; i--)
			if (b % i == 0 && a % i == 0)
			{
				printf("最大公约数为:");
				return i;
			}
	}
}
int main()
{
	printf("%d", Greatest_Common_Divisor(6,12));     //结果为:6
	printf("%d", Greatest_Common_Divisor(18, 12));   //结果为:6
}

调试结果为:

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值