解题步骤:
1、求最大公约数
对两个正整数a,b如果能在区间[a,0]或[b,0]内能找到一个整数temp能同时被a和b所整除,则temp即为最大公约数。
2、求最小公倍数
对两个正整数a,b,如果若干个a之和或b之和能被b所整除或能被a所整除,则该和数即为所求的最小公倍数。
//穷举法求两数的最大公约数
int divisor(int a,int b)
{
int temp;//定义义整型变量
temp=(a>b)?b:a;//采种条件运算表达式求出两个数中的最小值
while(temp>0){
if(a%temp==0&&b%temp==0)//只要找到一个数能同时被a,b所整除,则中止循环
break;
temp--;//如不满足if条件则变量自减,直到能被a,b所整除
}
return temp;//返回满足条件的数到主调函数处
}
//穷举法求两数的最小公倍数
int multiple(int a,int b)
{
int p,q,temp;
p=(a>b)?a:b;//求两个数中的最大值
q=(a>b)?b:a;//求两个数中的最小值
temp=p;//最大值赋给p为变量自增作准备
while(1){//利用循环语句来求满足条件的数值
if(p%q==0)
break;//只要找到变量的和数能被a或b所整除,则中止循环
p+=temp;//如果条件不满足则变量自身相加
}
return p;
}
用穷举法解题时,就是按照某种方式列举问题答案的过程。针对问题的数据类型而言,常用的列举方法一有如下三种:
(1)顺序列举是指答案范围内的各种情况很容易与自然数对应甚至就是自然数,可以按自然数的变化顺序去列举。
(2)排列列举有时答案的数据形式是一组数的排列,列举出所有答案所在范围内的排列,为排列列举。
(3)组合列举当答案的数据形式为一些元素的组合时,往往需要用组合列举。组合是无序的。
例子如下:在公元五世纪我国数学家张丘建在其《算经》一书中提出了“百鸡问题”:
“鸡翁一值钱5,鸡母一值钱3,鸡雏三值钱1。百钱买百鸡,问鸡翁、母、雏各几何?”这个数学问题的数学方程可列出如下:
Cock+Hen+Chick=100
Cock*5+Hen*3+Chick/3=100
显然这是个不定方程,适用于穷举法求解。依次取Cock值域中的一个值,然后求其他两个数,满足条件就是解。
该问题的C语言程序算法如下:
int Cock,Hen,Chick;/*定义公鸡,母鸡,鸡雏三个变量*/
Cock=0;
while(Cock<=19)/*公鸡最多不可能大于19*/
{Hen=0;
whlie(Hen<=33)/*母鸡最多不可能大于33*/
{Chick=100-Cock-Hen;
if(Cock*15+Hen*9+Chick==300)/*为了方便,将数量放大三倍比较*/
printf("\n公鸡=%d\n母鸡=%d\n雏鸡=%d",Cock,Hen,Chick);
Hen=Hen+1;
}
Cock=Cock+1;
}
参考资料:
这是求最小公倍数和最大公约数的函数,希望对你有所帮助。
本回答被提问者采纳调用函数的做法如图所示。
c语言如何求最小公倍数和最大公约数
对两个正整数a,b,如果若干个a之和或b之和能被b所整除或能被a所整除,则该和数即为所求的最小公倍数。\/\/穷举法求两数的最大公约数 int divisor(int a,int b){ int temp;\/\/定义义整型变量 temp=(a>b)?b:a;\/\/采种条件运算表达式求出两个数中的最小值 while(temp>0){ if(a%temp=...
c语言求最大公约数最小公倍数
c语言求最大公约数最小公倍数方法如下:1、利用定义法求最大公因数和最小公倍数。2、最小公倍数求法同上,最大公约数方法不同。3、利用辗转相除法求最大公约数和最小公倍数。
c语言求最大公约数和最小公倍数
c语言求最大公约数和最小公倍数 求最小公倍数算法: 最小公倍数=两整数的乘积÷最大公约数 求最大公约数算法: (1)辗转相除法 有两整数a和b:① a%b得余数c ② 若c=0,则b即为两数的最大公约数 ③ 若c≠0,则a=b,b=c,再回去执行① 例如求27和15的最大公约数过程为: 27÷1...
c语言辗转相除法求最大公约数和最小公倍数
3、辗转相除法: 是求最大公约数的一种方法。即用较小数除较大数,再用出现的余数(第一余数)去除除数,再用出现的余数(第二余数)去除第一余数,如此反复,直到最后余数是0为止。如果是求两个数的最大公约数,那么最后的除数就是这两个数的最大公约数。
求最大公约数和最小公倍数c语言
27÷15 余1215÷12余312÷3余0因此,3即为最大公约数。求最小公倍数:如图所示 C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言以及不需要任何运行环境支持便能运行的高效率程序设计语言。
c语言怎么求最大公约数和最小公倍数
C语言求最大公约数:对两个正整数a,b如果能在区间[a,0]或[b,0]内能找到一个整数temp能同时被a和b所整除,则temp即为最大公约数。求最小公倍数:对两个正整数a,b,如果若干个a之和或b之和能被b所整除或能被a所整除,则该和数即为所求的最小公倍数。C语言是一门面向过程、抽象化的...
c语言最大公约数和最小公倍数
在C语言中,可以使用欧几里得算法(辗转相除法)来计算两个数的最大公约数(GCD),然后使用最大公约数和最小公倍数的关系来计算最小公倍数(LCM)。求最大公约数的方法:方法一:穷举法 先令最大公约数max为1,当俩个数X、都能被循环变量i整除时,把循环变量赋值给最大公约数mx,这样在循环结束...
c语言最大公约数最小公倍数
c语言最大公约数最小公倍数如下:从键盘输入两个正整数a和b,求其最大公约数和最小公倍数。算法思想:利用格式输入语句将输入的两个数分别赋给a和b,然后判断a和b的关系,如果a小于b,则利用中间变量t将其互换。再利用辗转相除法求出最大公约数,进而求出最小公倍数。最后用格式输出语句将其...
如何用c语言解决求两数的最大公约数和最小公倍数?
1 对所有可能的数进行遍历。2 对每个数,求得另外一个数。3 计算两数的最大公约数和最小公倍数,判断是否可以整除且商为120.4 如果符合,则为该数。否则继续。代码如下:include <stdio.h>int main(){ int n,m,gcd, lcd; for(n = 1; n < 334; n ++)\/\/对可能的n遍历。
c语言求最大公约数和最小公倍数?
\/* 最大公约数 *\/ int gcd(int a, int b) { if (b == 0) { return a;} else { return gcd(b, a % b);} } \/* 最小公倍数 *\/ int lcm(int a, int b) { int max = a > b ? a : b;while (1) { if (max % a == 0 && max % b == 0) { return max;...