其他分享
首页 > 其他分享> > c语言作业,写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这个两个函数,并输出结果。两个整数由键盘输入。

c语言作业,写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这个两个函数,并输出结果。两个整数由键盘输入。

作者:互联网

思路就是先定义两个函数,一个解决最大公约数,一个最小公倍数,定义整形变量a,b用来接收两个输入整数。

最大公约数,定义一个整数i,用if语句使a,b最小值赋值给i,for语句初值为a,b中最小数,i--,循环到a和b可以同时整除i, i就是a和b的最大公约数,用break函数结束循环。

最小公倍数,定义一个整数i,用if语句使a,b最大值赋值给i,for语句初值为a,b中最大数,i++,循环到i可以同时整除a和b,i就是a和b的最小公倍数,用break函数结束循环。


#include<stdio.h>
int gys(int a,int b);       //声明gys函数解决最大公约数的函数
int gbs(int a,int b);       //声明gbs函数解决最小公倍数的函数
void main()
{ int i,j;                  //定义两个整形变量来接受两个整数
printf("请输入两个整数:");
scanf("%d%d",&i,&j);        //输入两个整数
printf("最大公约数为:%d\n",gys(i,j));  //使用gys函数输出最大公约数  
printf("最小公倍数为:%d\n",gbs(i,j));  //使用gbs函数输出最小公倍数
}
int gys(int a,int b)        //定义gys函数
{ int i;                    
if(a<b)                     //判断a是否小于b,小于的话互换值,使b为最小数
{ i=a;                      
  a=b;                      //使b为a,b中最小数,给for循环用
  b=i;
}
for(i=b;i>0;i--)            //由于使用的是i--,可以找到最先被a和b整除的数
if(a%i==0&&b%i==0)          //用if语句判断i减到几可以a和b整除
  { return i;               //函数返回值给到i,因为i最先被a和b整除,说明i为最大公约数
    break;                  //因为已经找到答案,直接结束循环,用break语句
  }
}                           //了解了最大公约数怎么求,那么最小公倍数就更好算了
int gbs(int a,int b)        
{                              
int i;                      //首先定义一个整形变量,用来接替a和b中的最大值
if(a>b)                     //利用if语句,使b是a和b中最大数
{ i=a;                  
  a=b;
  b=i;
}
for(i=b;i>0;i++)            //使i初值为a,b中最大数,i++
if(i%a==0&&i%b==0)          //直到i可以同时整除a和b
 { return i;                //把i的值返回给gbs函数
   break;                   //已经找到答案,可提前结束循环
 }                 
}                           //over

 

标签:两个,函数,int,整数,公倍数,最大公约数,gys,gbs
来源: https://blog.csdn.net/wobuhuijisuanji/article/details/122754684