C语言求最大公约数最小公倍数(多种方法)

前言

  • 这个求解方式多样化,灵活变动,但是,网上没有很好的资源和很全的代码,特此练习,敲打后,总结成本片文章.

单一求解

一.最大公约数

1.穷举法(最简单求解方式)

  • 利用除法方式用当前的数字不断去除以比较小的那个数的范围,最后得到两个数都可以整除的那个数.(这种方法也是最容易想到的)

核心代码

// 用比较小的一个数作为循环范围,然后不断减少,以便求出最后的公约数
void getResult(int a, int b, int min)
{
	for (int i = min; i > 1; i--)
	{
		if (a%i == 0 && b%i == 0)
		{
			printf("%d %d的最大公约数是:%d\n", a, b, i);
		}
	}
}

完整代码

#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b, int min);


int main()
{
	maxCommonNumber();
	
	system("pause");
	
	return 0;

}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");
	
	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);
	
	}

}

// 用比较小的一个数作为循环范围,然后不断减少,以便求出最后的公约数
void getResult(int a, int b, int min)
{
	for (int i = min; i > 1; i--)
	{
		if (a%i == 0 && b%i == 0)
		{
			printf("%d %d的最大公约数是:%d\n", a, b, i);
		}
	}
}
  • 优化算法
#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b, int min);


int main()
{
	maxCommonNumber();
	
	system("pause");
	
	return 0;

}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");
	
	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);
	
	}

}

// 优化算法
void getResult(int a, int b, int min) {

	int temp = 0;
	
	// 接收最小的值,对这个值进行操作,因为没用指针,所以这里用变量接收值修改
	temp = min;
	
	while (temp > 0)
	{
		if (a%temp == 0 && b%temp == 0)
		{
	
			break;
		}
	
		temp--;
	}
	
	printf("[%d %d]的最大公约数是:%d\n", a, b, temp);

}

2.递减法操作

  • 通过不断的相减获取最大公约数.

核心代码


// 优化算法
void getResult(int a, int b, int min) {

		int temp_A = 0;
		int temp_B = 0;
	
		// 接收最小的值,对这个值进行操作,因为没用指针,所以这里用变量接收值修改
		temp_A = a;
		temp_B = b;
	
		while (temp_A != temp_B)
		{
			if (temp_A > temp_B)
			{
				temp_A = temp_A - temp_B;
	
			}
			else
			{
				temp_B = temp_B - temp_A;
			}
	
		}
	
		printf("[%d %d]的最大公约数是:%d\n", a, b, temp_A);

}

完整代码

#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b, int min);


int main()
{
	maxCommonNumber();
	
	system("pause");
	
	return 0;

}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;

	printf("请输入两个数:\n");
	
	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);
	
	}

}

// 优化算法
void getResult(int a, int b, int min) {

		int temp_A = 0;
		int temp_B = 0;
	
		// 接收最小的值,对这个值进行操作,因为没用指针,所以这里用变量接收值修改
		temp_A = a;
		temp_B = b;
	
		while (temp_A != temp_B)
		{
			if (temp_A > temp_B)
			{
				temp_A = temp_A - temp_B;
	
			}
			else
			{
				temp_B = temp_B - temp_A;
			}
	
		}
	
		printf("[%d %d]的最大公约数是:%d\n", a, b, temp_A);

}

3.辗转相除法

  • 不断的让两个数做除法运算。其原理基于两个整数的最大公约数等于其中较小的数和两数的相除余数的最大公约数

核心代码

// 优化算法
void getResult(int a, int b, int min) {

	int temp = 0;
	
	int temp_A = 0;
	int temp_B = 0;
	
	// 接收最小的值,对这个值进行操作,因为没用指针,所以这里用变量接收值修改
	temp_A = a;
	temp_B = b;
	
	while (temp_B != 0) // 余数不为0,继续相除,直到余数为0 
	{
		temp = temp_A % temp_B;
		temp_A = temp_B;
		temp_B = temp;
	}
	
	printf("[%d %d]的最大公约数是:%d\n", a, b, temp_A);

}

完整代码

#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b, int min);


int main()
{
	
	

	maxCommonNumber();
	
	system("pause");
	
	return 0;

}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");
	
	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);
	
	}

}

// 优化算法
void getResult(int a, int b, int min) {

	int temp = 0;
	
	int temp_A = 0;
	int temp_B = 0;
	
	// 接收最小的值,对这个值进行操作,因为没用指针,所以这里用变量接收值修改
	temp_A = a;
	temp_B = b;
	
	while (temp_B != 0) // 余数不为0,继续相除,直到余数为0 
	{
		temp = temp_A % temp_B;
		temp_A = temp_B;
		temp_B = temp;
	}
	
	printf("[%d %d]的最大公约数是:%d\n", a, b, temp_A);

}


4.递归法

核心代码

int gcd1(int x, int y) {

	int temp = x % y;

	if (temp == 0)
	{
		return y;
	}
	else
	{
		return(y, temp);
	}
}

完整代码


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b);

int gcd1(int x, int y);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);

	}

}

// 优化算法
void getResult(int a, int b) {

	int result = gcd1(a, b);

	printf("[%d %d]的最大公约数是:%d\n", a, b, result);
	
}

int gcd1(int x, int y) {

	int temp = x % y;

	if (temp == 0)
	{
		return y;
	}
	else
	{
		return(y, temp);
	}
}

5.位运算法

核心代码


int gcd(int x, int y) {
	// 交换x和y的值,然后进行y/x运算
	while (x ^= y ^= x ^= y %= x); 
	return y;
}

  • 其中
x ^= y ^= x ^= y %= x
  • 翻译为
假设 x=2;y=1;
拆分为:

x ^= y ^= x ^= y %= x

// 交换x和y的数字(这样就把x=2;y=1;变为x=2;y=1;)
x^=y; //  x = x ^ y;x的y次方 => x = 2 ^ 1; => x=2;
y^=x; //  x = x ^ y;x的y次方 => y = 1 ^ 2; => y=1;
x^=y; //  x = x ^ y;x的y次方 => x = 2 ^ 1; => x=2;

// y对x取模
y%=x; // y = y % x; y除以x的余数 => y = 1%2 => y=2;



完整代码


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b);

int gcd1(int x, int y);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, b);
		
	}
	else {
		getResult(a, b,a);

	}

}

// 优化算法
void getResult(int a, int b) {

	int result = gcd1(a, b);

	printf("[%d %d]的最大公约数是:%d\n", a, b, result);
	
}

int gcd1(int x, int y) {

	// 交换x和y的值,然后进行y/x运算
	while (x ^= y ^= x ^= y %= x);
	return y;
}


二.最小公倍数

1.穷举法

核心代码


void getResult(int a, int b,int max) {

	int temp = 0;
	for (int i = max; i <= (a*b); i++)
	{
		if (i%a == 0 && i%b == 0)
		{
			temp = i;
			break;
		}
	}

	printf("[%d %d]的最小公倍数是:%d\n", a, b, temp);
	

完整代码


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b, int max);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b, a);
		
	}
	else {
		getResult(a, b,b);

	}

}

// 优化算法
void getResult(int a, int b,int max) {

	int temp = 0;
	for (int i = max; i <= (a*b); i++)
	{
		if (i%a == 0 && i%b == 0)
		{
			temp = i;
			break;
		}
	}

	printf("[%d %d]的最小公倍数是:%d\n", a, b, temp);
	
}



2.辗转相除法

核心代码


// 优化算法
void getResult(int a, int b) {

	// 用于自增的变量
	int temp = 0;

	// 接收最小公倍数最后的结果
	int gongbei = 0;

	// ===== 没有使用指针,所以,采用用变量接收修改参数值的方法 ******

	temp = a;

	// 获取两个数中较大的一个
	gongbei = a;

	while (1)
	{
		// 两个数中较大的数除以较小的数,能除开就说明最大的数就是两个数的最小公倍数
		if (gongbei%b == 0) {
			break;
		}

		// 较大的数除不开较小的数,最大的数就再加一个自己再循环除第二个数
		// 累加获得最小公倍数
		gongbei += temp;
	}

	printf("[%d %d]的最小公倍数是:%d\n", a, b, gongbei);
	
}

完整代码


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b);
		
	}
	else {
		getResult(a, b);

	}

}

// 优化算法
void getResult(int a, int b) {

	// 用于自增的变量
	int temp = 0;

	// 接收最小公倍数最后的结果
	int gongbei = 0;

	// ===== 没有使用指针,所以,采用用变量接收修改参数值的方法 ******

	temp = a;

	// 获取两个数中较大的一个
	gongbei = a;

	while (1)
	{
		// 两个数中较大的数除以较小的数,能除开就说明最大的数就是两个数的最小公倍数
		if (gongbei%b == 0) {
			break;
		}

		// 较大的数除不开较小的数,最大的数就再加一个自己再循环除第二个数
		// 累加获得最小公倍数
		gongbei += temp;
	}

	printf("[%d %d]的最小公倍数是:%d\n", a, b, gongbei);
}

3.通过公约数获取

核心代码


int function_my(int x, int y) {
	return x * y / gcd1(x, y);
}

完整代码


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b);

int gcd1(int x, int y);

int function_my(int x, int y);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);


	if (a > b)
	{
		getResult(a, b);
		
	}
	else {
		getResult(a, b);

	}

}

// 优化算法
void getResult(int a, int b) {

	
	int result = function_my(a, b);

	printf("[%d %d]的最小公倍数是:%d\n", a, b, result);
}

int gcd1(int x, int y) {

	// 交换x和y的值,然后进行y/x运算
	while (x ^= y ^= x ^= y %= x);
	return y;
}

int function_my(int x, int y) {
	return x * y / gcd1(x, y);
}

合并求解

最大公约和最小公倍一起求


#define _CRT_SECURE_NO_WARNINGS 1


// 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <stdio.h>
#include <stdlib.h>

void maxCommonNumber();

void getResult(int a, int b);

int gcd1(int x, int y);

int function_my(int x, int y);


int main()
{
	maxCommonNumber();
	
    system("pause");
	
	return 0;
}

void maxCommonNumber() {

	int a = 0;
	int b = 0;
	int result = 0;


	printf("请输入两个数:\n");

	printf("请输入第一个数a:");
	scanf("%d", &a);


	printf("请输入第二个数b:");
	scanf("%d", &b);

	getResult(a, b);

}

// 结果
void getResult(int a, int b) {

	int yue = gcd1(a, b);

	printf("[%d %d]最大公约数:%d\n", a, b, yue);

	int bei = function_my(a, b);

	printf("[%d %d]最小公倍数:%d\n", a, b, bei);

}

int gcd1(int x, int y) {

	// 交换x和y的值,然后进行y/x运算
	while (x ^= y ^= x ^= y %= x);
	return y;
}

int function_my(int x, int y) {
	return x * y / gcd1(x, y);
}

posted @ 2022-04-07 22:14  北极的大企鹅  阅读(138)  评论(0编辑  收藏  举报
阅读 - 79万