假设m是大的,n是小的。
1、判断m能否被n整除,如果能,则最大公约数就是n。
2、k=m-n。比较n和k,假设n大,k小。m=n; n=k; 重复第1步骤。直到m能被n整除为止。
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。
参考资料来源:百度百科-最大公约数
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,这个时候小的数就是两数的最大公约数,然后将输入的两个数相乘再除以做大公约数,得到的结果就是最小公倍数