数论之最大公约数和最小公倍数

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">1.最大公约数                                                                                                                                                                                                                                                                                             </span>

1.1 辗转相除法f(x,y)=f(x,x%y), f表示最大公约数函数:k=x/y;b=x%y;则z=k*y+b. 所以一个数能够被x, y 同时整除,则这个数也同时能够被y, x%y 整除。

int gcd(int x, int y){
	int temp;
	while(y){			
			temp=x%y;
			x=y;
			y=temp;	
	}
	return x;
}

int gcd_recursion(int x, int y){

	return (!y)?x:gcd_recursion(y,x%y);
}


1.2 辗转相减法,一个数能够被x, y 同时整除,则这个数也同时能够被y, x-y 整除


int gcd_subtraction(int x, int y){

	int temp;
        while(y){
			if(x>y){
			temp=x-y;
			x=y;
			y=temp;}
			else{
				temp=y-x;
				y=x;
				x=temp;
			}
		}
		return x;
}
int gcd_subtraction_recursion(int x, int y){

	if(x<y)
		return gcd_subtraction_recursion(y,x);

	    return (!y)?x:gcd_subtraction_recursion(y,x-y);
}
2.最小公倍数=积 除以 两数的最大公约数 : u=(a*b)/f(a,b)

int lcm(int x, int y){

	int z=gcd(x,y);
	return x*y/z;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值