c语言,求两个数m和n的最大公约数的流程图。

那个,不是这种的,是那种图的,流程图~~

假设m是大的,n是小的。

1、判断m能否被n整除,如果能,则最大公约数就是n。

2、k=m-n。比较n和k,假设n大,k小。m=n; n=k; 重复第1步骤。直到m能被n整除为止。

#include "stdio.h" //包含头文件

main()

{

int m,n,i,min; //定义变量

printf("Please Input n and m:\n"); //打印这句话

scanf("%d%d",&n,&m); //输入n和m的值

min=n>m?m:n; //条件zhi运算符,判断n、m那个dao最小,并将最小值赋给变量min

for(i=min;;i--) //从最小值起循环,每次减一

if(n%i==0&&m%i==0) //当循环到某一值的时候,n和m都能被i整除,即i为最小公约数

break; //当i为最大公约数时,退出循环

printf("common divisor: %d\n",i); //打印最大公约数

}

当知道最大公约数时,最小公倍数=(m)乘以(n)除以(最大公约数)

扩展资料:

例如:求24和60的最大公约数,先分解质因数,得24=2×2×2×3,60=2×2×3×5,24与60的全部公有的质因数是2、2、3,它们的积是2×2×3=12,所以,(24,60)=12。

例如:求6和15的最小公倍数。先分解质因数,得6=2×3,15=3×5,6和15的全部公有的质因数是3,6独有质因数是2,15独有的质因数是5,2×3×5=30,30里面包含6的全部质因数2和3,还包含了15的全部质因数3和5,且30是6和15的公倍数中最小的一个,所以[6,15]=30。

参考资料来源:百度百科-最大公约数

温馨提示:内容为网友见解,仅供参考
第1个回答  2015-10-23

  流程图如下:

  

第2个回答  2012-02-08
假设m是大的,n是小的。
1、判断m能否被n整除,如果能,则最大公约数就是n。如果不能则进行下一步骤。
2、k=m-n。比较n和k,假设n大,k小。m=n; n=k; 重复第1步骤。直到m能被n整除为止。

编程:
int big_divisor(int m, int n)
{
int min,max,k=m;
do
{
max=MAX(k,n);
min=MIN(k,n);
m=max;
n=min;
k=m%n;
}while(k!=0)
return n;
}

比如:8和4,8能被4整除,所以不需要第2步。
比如:12和8,12不能被8整除,所以进行第2步,循环1次后m和n分别是8和 12-8 即8和4,此时8能被4整除,所以循环结束,返回最大公约数4
第3个回答  2012-02-07
前提是int型的数。
#include <iostream>
using namespace std;
int fcn();
void main()
{
cout<<fcn()<<endl;
}
int fcn()
{
int a,b;
cin>>a>>b;// 最大公约数
return (a % b == 0)? b : gcd ( b, a % b ) ; }
}本回答被提问者采纳

c语言,求两个数m和n的最大公约数的流程图。
1、判断m能否被n整除,如果能,则最大公约数就是n。2、k=m-n。比较n和k,假设n大,k小。m=n; n=k; 重复第1步骤。直到m能被n整除为止。include "stdio.h" \/\/包含头文件 main(){ int m,n,i,min; \/\/定义变量 printf("Please Input n and m:\\n"); \/\/打印这句话 scanf("%d%d"...

c语言,求两个数m和n的最大公约数的流程图。
1、判断m能否被n整除,如果能,则最大公约数就是n。如果不能则进行下一步骤。2、k=m-n。比较n和k,假设n大,k小。m=n; n=k; 重复第1步骤。直到m能被n整除为止。编程:int big_divisor(int m, int n){ int min,max,k=m;do { max=MAX(k,n);min=MIN(k,n);m=max;n=min;k=...

c语言编程:输入两个正整数m和n,求其最大公约数和最小公倍数,急!...
int p,r,n,m,temp;printf("Please enter 2 numbers n,m:");scanf("%d,%d",&n,&m);\/\/输入两个正整数.if(n<m)\/\/把大数放在n中,把小数放在m中.{temp=n;n=m;m=temp;} p=n*m;\/\/P是原来两个数n,m的乘积.while(m!=0)\/\/求两个数n,m的最大公约数.{ r=n%m;n=m;m=r;...

C语言编程:输入两个正整数m和n,求它们的最大公约数。
int m,n;scanf("%d%d",&m,&n);printf("%d\\n",gcd(m,n));return 0;}

求两个数m和n的最大公约数?用NS图怎么画?
利用辗转相除法即可。NS流程图很容易画了我就不画了。代码如下:int MaxFactor(const int &m,const int &n){ if(m<n) \/\/默认为m>n,若不是,则交换 return MaxFactor(n,m); if(m%n==0) \/\/能整除,最大为n return n; else \/\/不能整除,辗转相除 return ...

C语言求最大公约数
求最大公约数是编程练习中常见问题。给定两个数m和n,目标是找出它们的最大公约数。通常,我们首先确定m和n中较小的数,然后不断递减,直到找到能同时被m和n整除的数。这种方法虽然简单,但效率不高。幸运的是,利用辗转相除法,我们能更高效地解决这个问题。连续正整数互质特性使辗转相除法成为理想...

C语言求两个数m、n的最大公约数。(带注释)
m = n,n = a,继续求余 否则(即若a为0)n 为最大公约数 gcd(int a,int b){ int t;if (a < b)t=a,a=b,b=t;if (b == 0)return a;else t= a%b;while (t!= 0){ a=b;b=t;t=a%b;} return b;} main(){ int a,b;printf("输入两个数字:");scanf("%d%d",&a...

C语言题目,输入两个正整数m和n,求其最大公约数和最小公倍数
最大公约数:(辗转相除法)调整顺序使m>=n 循环 m=m%n; 如果m=0,则n为最大公约数,跳出循环。注:%表示取余运算。n=n%m; 如果n=0,则m为最大公约数,跳出循环。next 求出最大公约数G后,用m*n\/G得到最小公倍数。

c语言中m、 n的最大公因数是多少?
输入两个正整数m和n,求其最大公约数和最小公倍数。解:程序:include <stdio.h> int main(){ int num1, num2, t,p;printf("请输入两个正整数:");scanf("%d,%d", &num1, &num2);\/\/7,8 p = num1*num2;while (t = num1%num2)\/\/7 1 0,循环结束 { num1 = n...

用C程序编写:输出两个正整数m和n,求其最大公约数和最小公倍数。
我给楼主说下思路:先输入两个整数,然后判断两数的大小,用大的数对小的取模,然后小的数自减直到余数为0,这个时候小的数就是两数的最大公约数,然后将输入的两个数相乘再除以做大公约数,得到的结果就是最小公倍数

相似回答