输入两个正整数m和n,求其最大公约数和最小公倍数?(用C语言)

作者&投稿:植羽 (若有异议请与网页底部的电邮联系)
用C语言编写程序:输入两个正整数m,n.求其最大公约数和最小公倍数~

C语言经典例子之求其最大公约数和最小公倍数

#include
int main(){
int a,b,num1,num2,temp;
printf("please input two number:
");
scanf("%d%d",&num1,&num2);
if(num1<num2){
temp = num1;
num1 = num2;
num2 = temp;
}
a = num1;
b = num2;
while(b!=0){
temp = a%b;
a=b;
b=temp;
}
printf("gongyueshu:%d
",a);
printf("gongbeishu:%d
",num1*num2/a);
}

扩展资料:

C语言循环控制语句
一、while语句
1、计算while后面括号里表达式的值,若其结果非0,则转入2,否则转3
2、执行循环体,转1
3、退出循环,执行循环体下面的语句。
由于是先执行判断后执行循环体,所以循环体可能一次都不执行。
二、do...while语句
1、执行循环体,转2
2、计算while后面括号里表达式的值,若其结果非0,则转入1,否则转3
3、退出循环,执行循环体下面的语句。

输入两个正整数m和n, 求其最大公约数和最小公倍数.

用辗转相除法求最大公约数
算法描述:
m对n求余为a, 若a不等于0
则 m <- n, n <- a, 继续求余
否则 n 为最大公约数
最小公倍数 = 两个数的积 / 最大公约数

#include
int main()
{
int m, n;
int m_cup, n_cup, res; /*被除数, 除数, 余数*/
printf("Enter two integer:\n");
scanf("%d %d", &m, &n);
if (m > 0 && n >0)
{
m_cup = m;
n_cup = n;
res = m_cup % n_cup;
while (res != 0)
{
m_cup = n_cup;
n_cup = res;
res = m_cup % n_cup;
}
printf("Greatest common divisor: %d\n", n_cup);
printf("Lease common multiple : %d\n", m * n / n_cup);
}
else printf("Error!\n");
return 0;
}

★ 关于辗转相除法, 搜了一下, 在我国古代的《九章算术》中就有记载,现摘录如下:

约分术曰:“可半者半之,不可半者,副置分母、子之数,以少减多,更相减损,求其等也。以等数约之。”

其中所说的“等数”,就是最大公约数。求“等数”的办法是“更相减损”法,实际上就是辗转相除法。

辗转相除法求最大公约数,是一种比较好的方法,比较快。

对于52317和75569两个数,你能迅速地求出它们的最大公约数吗?一般来说你会找一找公共的使因子,这题可麻烦了,不好找,质因子大。

现在教你用辗转相除法来求最大公约数。

先用较大的75569除以52317,得商1,余数23252,再以52317除以23252,得商2,余数是5813,再用23252做被除数,5813做除数,正好除尽得商数4。这样5813就是75569和52317的最大公约数。你要是用分解使因数的办法,肯定找不到。

那么,这辗转相除法为什么能得到最大公约数呢?下面我就给大伙谈谈。

比如说有要求a、b两个整数的最大公约数,a>b,那么我们先用a除以b,得到商8,余数r1:a÷b=q1…r1我们当然也可以把上面这个式子改写成乘法式:a=bq1+r1------l)

如果r1=0,那么b就是a、b的最大公约数3。要是r1≠0,就继续除,用b除以r1,我们也可以有和上面一样的式子:

b=r1q2+r2-------2)

如果余数r2=0,那么r1就是所求的最大公约数3。为什么呢?因为如果2)式变成了b=r1q2,那么b1r1的公约数就一定是a1b的公约数。这是因为一个数能同时除尽b和r1,那么由l)式,就一定能整除a,从而也是a1b的公约数。

反过来,如果一个数d,能同时整除a1b,那么由1)式,也一定能整除r1,从而也有d是b1r1的公约数。

这样,a和b的公约数与b和r1的公约数完全一样,那么这两对的最大公约数也一定相同。那b1r1的最大公约数,在r1=0时,不就是r1吗?所以a和b的最大公约数也是r1了。

有人会说,那r2不等于0怎么办?那当然是继续往下做,用r1除以r2,……直到余数为零为止

int gcd(int, int); //两个数的最大公约数
int ngcd(int *, int) //N个数的最大公约数
int lcm(int, int) //两个数的最小公倍数
int nlcm(int *, int) //N个数的最小公倍数

int gcd(int a, int b)
{
if(a < b) //swap(a,b)
{
a = a ^ b;
b = a ^ b;
a = a ^ b;
}

int c;
while((c = a % b) != 0) //辗转相除
{
a = b;
b = c;
}
return b;
}

int ngcd(int * pa, int n)
{
if(n == 1)
return *pa;
return (gcd(pa[n-1], ngcd(pa, n-1)));
}

int lcm(int a, int b) //最大公倍数 = 两数乘积 / 最大公约数
{
return a*b/gcd(a, b);
}

int nlcm(int * pa, int n)
{
if(n == 1)
return *pa;
return lcm(pa[n-1], nlcm(pa, n-1));
}

#include<stdio.h>
void main()
{int a,b,c,d,m;
printf("Please Input two Integer:");
scanf("%d%d",&c,&d);
if(c>d)
{m=d;d=c;c=m;}
a=c;b=d;
while(b!=0)
{
m=a%b;a=b;b=m;
}
printf("最大公约数是:%d\n",a);
printf("最小公倍数是:%d\n",c*d/a);}




请输入两个正整数,输入两个正整数m和n,求其最大公约数和最小公倍...
num1 = num2; \/\/8 7 num2 = t; \/\/7,循环继续 1 } p = p \/ num2;printf("它们的最大公约数:%d\\n", num2);printf("它们的最小公倍数:%d\\n", p);return 0;} 结果:请输入两个正整数:3,6 它们的最大公约数:3 它们的最小公倍数:6 ...

输入两个正整数m和n,求其最大公约数和最小公倍数
分三种情况:1、当m、n是互质数时,最大公约数是1,最小公倍数是它们的乘积。2、当m、n成倍数关系如:m为20,n为5时,最大公约数是m,最小公倍数是n。3、当m、n既不互质、也不是倍数关系时,如24和16,最大公约数是8,最小公倍 数是48。

编写程序,输入两个正整数m和n,输出m和n之间的素数并统计素数的个数...
1、打开visual studio软件,进入菜单“文件”->新建->新建项目。选择windows窗体程序,项目名为“SuShu”。2、在窗体上添加控件:lable控件,text值为“输入一个数,判断是否是素数”;一个textbox控件(tb_inputvalue),用来输入要判断的素数。3、素数设计算法。4、素数设计算法:取消检测区间,提高程序...

输入两个正整数m和n,求它们的最大公约数和最小公倍数(本题要求用辗转相...
则 m <- n, n <- a, 继续求余 否则 n 为最大公约数 <2> 最小公倍数 = 两个数的积 \/ 最大公约数 include int main(){ int m, n;int m_cup, n_cup, res; \/*被除数, 除数, 余数*\/ printf("Enter two integer:\\n");scanf("%d %d", &m, &n);if (m > 0 && n >...

C语言编程:输入两个正整数m和n,求它们的最大公约数。
printf("请输入两个正整数:\\n");scanf("%d,%d",&m,&n);if(m<n){t=m;m=n;n=t;}for(y1=n;;y1--)if(m%y1==0&&n%y1==0){printf("最大公约数是:%d\\n",y1);y2=n*m\/y1;printf("最小公倍数是:%d\\n",y2); break;}return 0;} 四方袁走 | 发布于2018-02-12 举报| 评论 ...

C语言,编程输入两个正整数m和n(m<=n),求 S=1\/m+1\/(m+1)+1\/(m+2)+...
include<stdio.h> intmain(){ int m,n;double s=0,k;scanf("%d,%d",&m,&n);while(m<=n){ k=m;s+=(1\/k);m++;printf("%d,%d,%.10f\\n",m,n,s);} }

编写程序,输入两个正整数m和n,输出m和n之间的素数并统计素数的个数.要...
3、素数设计算法。4、素数设计算法:取消检测区间,提高程序效率。我们可以只判断2到n\/2之间的数,就可以知道他是不是素数了。5、获取前100之间的所有素数:从2到一百挨个判断,是素数就记录下来。6、判断一个数是不是素数:if (sushu(Int32.Parse(tb_inputvalue.Text))) {MessageBox.Show(tb_...

1、 输入2个正整数m和n(1<=m,n<=6),然后输入该m行n列矩阵a中的元素,分 ...
printf("第%d行的和为%d\\n",i+1,s); }} 本回答由提问者推荐 举报| 答案纠错 | 评论 18 7 jiweix 采纳率:66% 擅长: 编程语言 互联网 操作系统\/系统故障 常见软件 为您推荐: 输入两个正整数m和n 输入正整数m和n vb 输入整数n<=20 输入20正整数 从键盘输入10个整数 输入正整数n<=20 ...

.输入两个正整数m和n,求其最大公约数和最小公倍数。这个程序怎么编啊...
输入两个正整数m和n, 求其最大公约数和最小公倍数.<1> 用辗转相除法求最大公约数 算法描述:m对n求余为a, 若a不等于0 则 m <- n, n <- a, 继续求余 否则 n 为最大公约数 <2> 最小公倍数 = 两个数的积 \/ 最大公约数 include <stdio.h> int main(){ int m, n;int m_...

输入两个正整数m和n(1<=m, n<=1000),输出m与 n之间含m,n)的所有满足各...
在倒数第3个}前加一句i=t;。因为你把循环控制变量i人为改变了,使用循环乱套了。好在i的正确值赋给了t,所以用i=t;可以恢复。当然可以另外处理。将printf("%d",t);改为printf("%d ",t);,不然输出的数是连在一起的。在最后一个}前加一句return 0;,否则会有编译警告。

大竹县15290436026: 设计一个C程序解决这个题:输入两个正整数m和n,求其最大公约数和最小公倍数.写出完整的程序 -
桓祥阿法:[答案] #include void main() { int a,b,m,n,p,t; printf("请按顺序输入a和b\n"); scanf("%d,%d",&a,&b); p=a*b; do {m=a%b;t=b;a=b;b=m; } while(m!=0); n=p/t; printf("a和b的最大公约数是%d\n最小公倍数是%d\n",t,n); }...

大竹县15290436026: 输入两个正整数m和n,求它们的最大公约数和最小公倍数.(习题6.1) -
桓祥阿法:[答案] 输入两个正整数m和n,求其最大公约数和最小公倍数.用辗转相除法求最大公约数 算法描述:m对n求余为a,若a不等于0 则 m 0) { m_cup = m; n_cup = n; res = m_cup % n_cup; while (res != 0) { m_cup = n_cup; n_cup = re...

大竹县15290436026: 编写一个函数,对于两个正整数m和n,求其最大公约数fum -
桓祥阿法:[答案] //用辗转相除法球最大公约数int fum(int m,int n) //fum求m和n的最大公约数{ int tmp,r; if(mn&n...

大竹县15290436026: 在主函数中由键盘输入两个正整数m和n,写两个函数分别求取它们的最大公约数和最小公倍数,在主 -
桓祥阿法:[答案] input int m,n; int p=m,q=n,t; while(t!=0) { t=p%q; p=q; q=t; } int MaxGys=p; int MinGbs=m*m/p;

大竹县15290436026: C语言编程题输入两个正整数m和n,求其最大公约数和最小公倍数请编
桓祥阿法: #include "stdio. h" void main(){ int m,n,temp,a,b; printf("请输入2个正整数m和n:"); scanf("%d%d",&m,&n); a=m; b=n; if(m全部

大竹县15290436026: 题目:输入两个正整数m和n,求其最大公约数和最小公倍数. (java)1.程序分析:利用辗除法请问,什么是辗除法? -
桓祥阿法:[答案] 设两数为a、b(b
大竹县15290436026: 实验四 循环结构练习 1.编写一个C程序,指定两个正整数m和n,求出它们的最大公约数和最小公倍实验四 循环结构练习1.编写一个C程序,指定两个正整数... -
桓祥阿法:[答案] 知道了

大竹县15290436026: 输入两个正整数m和n,求其最大公约数和最小公倍数 -
桓祥阿法: 分三种情况:1、当m、n是互质数时,最大公约数是1,最小公倍数是它们的乘积. 2、当m、n成倍数关系如:m为20,n为5时,最大公约数是m,最小公倍数是n. 3、当m、n既不互质、也不是倍数关系时,如24和16,最大公约数是8,最小公倍 数是48.

大竹县15290436026: 用C语言实现对键入两个正整数求最大公约数 -
桓祥阿法: 输入两个正整数m和n,求它们的最大公约数和最小公倍数 比如,输入m和n的值分别为14和21,则最大公约数为7,最小公倍数为42. #include<stdio.h> void main() {int m,n,i,j;scanf("%d%d",&m,&n);for(i=m;i>=1;i--){if (n%i==0&&m%i==0...

大竹县15290436026: 输入两个正整数m和n,求最大公约数和最小公倍数 -
桓祥阿法: 这个程序采用的是辗转相除法. 规则为: 1) n 和 m (n>m) 的最大公约数等于 m 和 n%m 的最大公约数. 2) 当 m为0 时,这时的 n 为 开始时的 n 和 m 的最大公约数

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网