辗转相除法c语言用函数 c语言编程辗转相除法

C语言辗转相除法

例如用辗转相除法求a b 最大公约数(a b谁大谁小无所谓):

创新互联建站的客户来自各行各业,为了共同目标,我们在工作上密切配合,从创业型小企业到企事业单位,感谢他们对我们的要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。专业领域包括网站建设、网站设计、电商网站开发、微信营销、系统平台开发。

int GCD( int a , int b )

{

int n=a%b;

whie(n != 0) //即: while(n)

{

a = b;

b = n;

n = a % b;

}

return b; //注意这里返回的是b 不是n

}

c语言辗转相除法

按照你的改了一下

#include stdio.h

int gcd(int x,int y)

{

int i;

int max,min;

(xy)?(max=x,min=y):(max=y,min=x);

if(i=max%min!=0)

do{

i=min;

min=max%min;

max=i;

}while(min!=0);

return max;

}

int main()

{

int a,b;

scanf("%d%d",a,b);

printf("%d\n",gcd(a,b));

return 0;

}

再给你一个精简版,二者实质是一样的

#include stdio.h

int gcd(int x,int y)

{

if(y==0) return x;

return gcd(y,x%y);

}

int main()

{

int a,b;

scanf("%d%d",a,b);

printf("%d\n",gcd(a,b));

return 0;

}

C语言函数辗转相除法!

#include stdio.h

/*辗转相除法函数*/

int gcd_div(int a,int b)

{

if (b == 0) {

return a;

} else {

return gcd_div(b,a % b);

}

}

/*更相减损法函数*/

int gcd_sub(int a,int b)

{

int ma,mb;

ab?(ma=a,mb=b):(ma=b,mb=a);

if (mb == 0) {

return ma;

} else {

return gcd_sub(ma-mb,mb);

}

}

int main()

{

int a = 28,b = 21;

printf("最大公约数(减法):(%d %d)%d\n",b,a,gcd_sub(b,a));

printf("最大公约数(除法):(%d %d)%d\n",b,a,gcd_div(a,b));

return 0;

}

什么是辗转相除法怎样用c语言编程实现,用辗转相除法

用辗转相除法(即欧几里得算法)求两个正整数的最大公约数.

解析:

设两个数m,n,假设m=n,用m除以n,求得余数q.若q为0,则m为最大公约数;若q不等于0,则进行如下迭代:

m=n,n=q,即原除数变为新的被除数,原余数变为新的除数重复算法,直到余数为0为止.余数为0时的除数n,即为原始m、n的最大公约数.

迭代初值:m,n的原始值;

q=m%n;

m=n;

n=q;

迭代条件:q!=0

例如:m=8;n=6

q=m%n(8%6==2)

m=n(m==6)

n=q(n==2)

因为:(q==2)!=0,重复算法:

q=m%n(6%2==0)

m=n(m==2)余数为0时的除数n为最大公约数,n值赋给了m,所以输出m的值

n=q(n==0)

因为:q==0 所以最大公约数为m的值

源程序:

#include

void main()

{

int m,n,q,a,b;

printf("Enter two integers:");

scanf("%d%d",a,b);

m=a;

n=b;

if(nm)

{

int z;

z=m;m=n;n=z;//执行算法前保证m的值比n的值大

}

do

{

q=m%n;

m=n;

n=q;

}while(q!=0);

printf("The greatest common divisor of");

printf("%d,%d is %d\n",a,b,m);

}

希望对你有所帮助!

辗转相除法c语言代码

辗转相除法用来求两个数的最大公约数,代码如下:

#include stdio.h

#include stdlib.h

int main()

{

int a, b,r;

scanf("%d %d", a, b);

while(b!=0)//当其中一个数为0,另一个数就是两数的最大公约数

{

r = a%b;

a = b;

b = r;

}

printf("Greatest Common Divisor: %d\n", a);

system("pause");

}

运行结果:


新闻标题:辗转相除法c语言用函数 c语言编程辗转相除法
分享网址:http://azwzsj.com/article/hiiijs.html