成都创新互联网站制作重庆分公司

c语言中求最大公约数函数,c语言最大公约数求法

c语言求最大公约数

1、新建一个C语言源程序,这里使用Visual C++6.0的软件:

创新互联建站主要从事成都做网站、网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务陇县,10多年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575

2、从键盘中输入两个正整数a和b。取两个数a,b中的较小值存放到变量n中。从两个数a和b中的较小数开始逐个减小1,寻找能整除a和b的整数,第一个找到的整数即整数a和b的最大公约数,最后将找到的结果输出即可完成程序的编写:

3、对源程序编译运行,测试输入4、6,得到最大公约数2说明程序是正确的,以上就是用c语言求最大公约数的过程:

c语言函数调用求最大公约数和最小公倍数

#includelt;stdio.hgt;

int a;

int _Y(int x,int y);

int main()

{

int a,b,c,d;

printf(“请输入数字:”);

scanf("%d,%d",c,d);//此处注意在输出的时候数字之间要打都好,不然输出结果错误

b=_Y(c,d);

a=c*d/b;

printf(“最大公约数为:%d\n”,b);

printf(“最小公倍数为:%d\n”,a);

return 0;

}

int _Y(int x,int y)

{

int e;

if(xlt;y)

{

e=x;

x=y;

y=e;

}

while((e=x%y)!=0)

{

x=y;

y=e;

}

return(y);

}

扩展资料:

while循环开始后,先判断条件是否满足,如果满足就执行循环体内的语句,执行完毕后再回来判断条件是否满足,如此无限重复;直到条件不满足时,执行while循环后边的语句。简单来讲就是说while循环是先判断后循环, 判断如果满足条件进入循环 本次循环后再次判断 。

举个例子:

do-while循环与while循环的不同在于:它先执行循环中的语句,然后再判断表达式是否为真, 如果为真则继续循环;如果为假, 则终止循环。因此, do-while循环至少要执行一次循环语句。 简单来讲就是说while循环是先循环后判断 。

举个例子:

总结:while循环是先判断后循环 ,而do–while循环是先循环后判断。

参考资料:

百度百科——while(循环语句及英文单词)

c语言求两个数的最大公约数是多少?

c语言求两个数的最大公约数的步骤如下:

1、首先,新建一个C语言源程序,在这里使用的是Visual C++6.0的软件。

2、然后从键盘中直接输入两个正整数a和b。

代码为:

printf("please input two number:\n");

int a,b;

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

3、然后取a,b这两个数中的较小值,存放到变量n中。

代码为:

int n=a;

if (nb)

n=b;

4、接着从两个数a和b中的较小数开始,依次逐个减小1,以便能寻找出可以整除a和b的整数。第一个找到的整数就是整数a和b的最大公约数。

代码:

for(int i=n;i=1;i--)

{

if (a%i==0b%i==0)

{

printf("最大公约数:%d \n",i);

break;

}

}

5、最后点击工具栏上方的图标,之后源程序编译运行,即可对数据进行计算。

以上就是c语言求两个数的最大公约数的步骤了。

C语言中求最大公约数的函数

#include

"stdio.h"

int

main()

{

int

d1,d2,r;

printf("输入两个正整数:");

scanf("%d

%d",d1,d2);

do

{

r=d1%d2;

d1=d2;d2=r;

}while(d2!=0);

printf("最大公约数是:%d",d1);

}

//递归法

#include

"stdio.h"

int

fun(int

d1,int

d2)

{

if(d2!=0)

return

fun(d2,d1%d2);

else

return

d1;

}

int

main()

{

int

d1,d2;

printf("输入两个正整数:");

scanf("%d

%d",d1,d2);

printf("最大公约数是:%d",fun(d1,d2));

}


文章题目:c语言中求最大公约数函数,c语言最大公约数求法
地址分享:http://cxhlcq.com/article/dsepdjc.html

其他资讯

在线咨询

微信咨询

电话咨询

028-86922220(工作日)

18980820575(7×24)

提交需求

返回顶部