前言

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

单一求解

一.最大公约数

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);
}

C语言求最大公约数最小公倍数(多种方法)的更多相关文章

  1. c语言求最大公约数和最小公倍数

    求最大公约数和最小公倍数 假设有两个数a和b,求a,b的最大公约数和最小公倍数实际上是一个问题,得出这两个数的最大公约数就可以算出它们的最小公倍数. 最小公倍数的公式是 a*b/m m为最大公约数 因 ...

  2. c语言求最大公约数和最小公倍数(转)

    最大公约数与最小公倍数的求解是很多初学C的人所面临的一道问题.当然这道问题并不难解答,也有很多人已经写过相关的博客,我在此书写此篇博客,一是为了让自己能够夯实基础,另外就是希望能够帮到和我一样的初学者 ...

  3. C语言 · 求最大公约数

    算法提高 求最大公约数   时间限制:1.0s   内存限制:512.0MB      编写一函数gcd,求两个正整数的最大公约数. 样例输入: 5 15样例输出:5 样例输入: 7 2样例输出:1 ...

  4. c语言求最大公约数

    求差判定法. 如果两个数相差不大,可以用大数减去小数,所得的差与小数的最大公约数就是原来两个数的最大公约数.例如:求78和60的最大公约数.78-60=18,18和60的最大公约数是6,所以78和60 ...

  5. Java求最大公约数和最小公倍数

    最大公约数(Greatest Common Divisor(GCD)) 基本概念 最大公因数,也称最大公约数.最大公因子,指两个或多个整数共有约数中最大的一个.a,b的最大公约数记为(a,b),同样的 ...

  6. C语言中如何求最大公约数及如何求最小公倍数。

    最大公约数:                                                                                               ...

  7. 常见算法:C语言求最小公倍数和最大公约数三种算法

    最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们的公倍数,当中一个最小的公倍数是他们的最小公倍数,相同地,若干个整数公有的倍数中最小的正整数称为它们的最小公倍数,维基百科:定义点击打开链接 求 ...

  8. C语言求最小公倍数和最大公约数三种算法(经典)

    把以前写的一些经验总结汇个总,方便给未来的学弟学妹们做个参考! --------------------------永远爱你们的:Sakura 最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们 ...

  9. C语言求最小公倍数和最大公约数三种算法

    最小公倍数:数论中的一种概念,两个整数公有的倍数成为他们的公倍数,其中一个最小的公倍数是他们的最小公倍数,同样地,若干个整数公有的倍数中最小的正整数称为它们的最小公倍数,维基百科:定义点击打开链接 求 ...

随机推荐

  1. SQL Server 2008安全加固手册

    1.身份鉴别 1.1避免使用空密码和弱口令 要求:应对登录操作系统和数据库系统的用户进行身份标识和鉴别. 目的:操作系统和数据库系统管理用户身份鉴别信息应具有不易被冒用的特点,口令应有复杂度要求并定期 ...

  2. java对xml文件的操作

    xml文件格式(示例): <?xml version="1.0" encoding="UTF-8"?> <root> <Funct ...

  3. .htaccess文件构成的PHP后门

    1..htaccess文件 2.文件上传绕过 一般.htaccess可以用来留后门和针对黑名单绕过 创建一个txt写入(png解析为php) AddType application/x-httpd-p ...

  4. CVE-2012-1823(PHP-CGI远程代码执行)

    基于vulhub漏洞环境: 安装vulhub漏洞环境 https://blog.csdn.net/qq_36374896/article/details/84102101 CGI模式下的参数: -c ...

  5. 为什么操作 DOM 慢?

    DOM本身是一个js对象, 操作这个对象本身不慢, 但是操作后触发了浏览器的行为, 如repaint和reflow等浏览器行为, 使其变慢

  6. Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?

    启动类上面的注解是@SpringBootApplication,它也是 Spring Boot 的核心注解,主要组合包含了以下 3 个注解: @SpringBootConfiguration:组合了 ...

  7. mac 安装shell

    https://blog.csdn.net/weixin_41937552/article/details/108565705

  8. Oracle入门基础(三)一一单行函数

    SQL> --字符函数 SQL> select lower('Hello World') 转小写,upper('Hello World') 转大写,initcap('hello world ...

  9. synchronized 关键字的用法?

    synchronized 关键字可以将对象或者方法标记为同步,以实现对对象和方法的互 斥访问,可以用 synchronized(对象) { - }定义同步代码块,或者在声明方法时 将 synchron ...

  10. CI_CD 简单了解