C语言求最大公约数和最小公倍数
C语言编写两个函数,分别求两个整数的最大公约数和最小公倍数,并用主函数调用这两个函数,然后输出结果。两个整数由键盘输入。约定最大公约数为正整数,两数里有负的则最小公倍数就为负的。
/*
开发者:慢蜗牛 开发时间:2020.5.28
程序功能:计算最大公约数和最小公倍数
*/
#include<stdio.h>
#include<math.h>
int max_(int a, int b);
int min_(int a,int b);
int max_(int a, int b)//求最大公约数
{
int n, little;
a = abs(a); b = abs(b);//取绝对值
little = a < b ? a : b;//取两数中最小值
for (n = little; n > 0; n--)
{
if (a % n == 0 && b % n == 0)
break;
else continue;
}
return n;
}
int min_(int a, int b)//求最小公倍数
{
int n, old;
old = abs(a) > abs(b) ? abs(a) : abs(b);//去两数的绝对值的最大值
for (n = old;; n++)
{
if (n % abs(a) == 0 && n % abs(b) == 0)
break;
else continue;
}
if (a < 0 || b < 0) return (-n);//根据有无正负,返回相关正负值
else return n;
}
void main()
{
int a, b;
int c, d;
while (1)//循环
{
scanf_s("%d,%d", &a, &b);
while(a == 0 || b == 0)//控制两数不等于0
{
printf("input error,please re-enter:\n");
scanf_s("%d,%d", &a, &b);
}
c=max_(a, b);//调用函数
d=min_(a, b);
printf("%d,%d\n", c, d);//输出
}
}