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);//输出

}

}