C语言第二十弹--求最大公因数

简介: C语言第二十弹--求最大公因数

求最大公因数

最大公因数:也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。

一、穷举法

思路:找到两个数之间的最少值 使用第三接收最小值,然后通过判断两者%n是否同时等于0,同时为0证明就是两者的最大公因数,不是就n–继续判断。

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>c
int main()
{
  //穷举法
  int a = 0;
  int b = 0;
  scanf("%d %d",&a,&b);
  int n = a > b ? b : a;//获取最小值
  while (a % n != 0 || b % n != 0)//作为判断条件
  {
    n--;
  }
  printf("%d",n);
  return 0;
}

二、辗转相除法

思路:两个数通过反复求模 获取到一个值,当两个数取模时值为0时证明该被取模的数就是两数的最大公因数。

例如 a = 24 b = 16 a % b = 8 此时a = 8,b = 16, 再次循环 b % a == 0 ,那么就证明a为最大公因数。需要注意的是 必须是大的数取余小的数 就需要进行判断。

总代码

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
  int a = 0;
  int b = 0;
  scanf("%d %d",&a,&b);
  while (a && b)
  {
    if (a > b)
    {
      a %= b;
    }
    else
    {
      b %= a;
    }
  }
  printf("%d",a > b ? a : b);
  return 0;
}

三、更相相损法

思路:两数通过不断相损(相减),当两者相等时,就是最大公因数。

例如 a = 24 b = 16,通过条件判断使 a -= b,那么此时a = 8 ,b = 16,再次进行条件判断 从而使 a = b,获得最大公因数。

总代码

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
  int a = 0;
  int b = 0;
  scanf("%d %d",&a,&b);
  while (a != b)
  {
    if (a > b)
    {
      a -= b;
    }
    else
    {
      b -= a;
    }
  }
  printf("%d",a);
  return 0;
}


相关文章
|
算法 搜索推荐 程序员
C语言第十二练——计算两个正整数的最小公倍数和最大公因数
C语言第十二练——计算两个正整数的最小公倍数和最大公因数
244 0
|
算法 搜索推荐 程序员
C语言第十练——实现求一个数的所有因数
C语言第十练——实现求一个数的所有因数
482 0
|
算法 C语言
C语言——最大公因数和最小公倍数
C语言——最大公因数和最小公倍数
766 0
|
存储 人工智能 BI
关于C语言中最大公因数的思考
如何去求最大公因数利用枚举法: 如何去求最大公因数利用辗转相除法: 例1:最大公因数使用for循环和if语句 示例2:最大公因数使用while循环和if ... else语句 例3:正负数均为最大公因数
256 0
|
C语言
关于C语言中最大公因数的思考
如何去求最大公因数利用枚举法,如何去求最大公因数利用辗转相除法
199 0
|
3月前
|
存储 C语言
`scanf`是C语言中用于按格式读取标准输入的函数
`scanf`是C语言中用于按格式读取标准输入的函数,通过格式字符串解析输入并存入指定变量。需注意输入格式严格匹配,并建议检查返回值以确保读取成功,提升程序健壮性。
1002 0
|
11月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
630 23
|
5月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
323 15
|
10月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
407 1
一文彻底搞清楚C语言的函数
|
11月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
544 15
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】