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


相关文章
|
6月前
|
算法 搜索推荐 程序员
C语言第十二练——计算两个正整数的最小公倍数和最大公因数
C语言第十二练——计算两个正整数的最小公倍数和最大公因数
76 0
|
6月前
|
算法 搜索推荐 程序员
C语言第十练——实现求一个数的所有因数
C语言第十练——实现求一个数的所有因数
115 0
|
存储 人工智能 BI
关于C语言中最大公因数的思考
如何去求最大公因数利用枚举法: 如何去求最大公因数利用辗转相除法: 例1:最大公因数使用for循环和if语句 示例2:最大公因数使用while循环和if ... else语句 例3:正负数均为最大公因数
116 0
|
C语言
关于C语言中最大公因数的思考
如何去求最大公因数利用枚举法,如何去求最大公因数利用辗转相除法
49 0
|
2天前
|
C语言
C语言:内存函数(memcpy memmove memset memcmp使用)
C语言:内存函数(memcpy memmove memset memcmp使用)
|
18小时前
|
C语言
C语言—内存函数的实现和模拟实现(内存函数的丝绸之路)
C语言—内存函数的实现和模拟实现(内存函数的丝绸之路)
16 0
|
18小时前
|
C语言
C语言—字符函数与字符串函数(字符问题变简单的关键之技)
C语言—字符函数与字符串函数(字符问题变简单的关键之技)
3 0
|
18小时前
|
C语言
C语言——函数递归
C语言——函数递归
4 0
|
18小时前
|
C语言
C语言—函数(大化小方式的心脏)
C语言—函数(大化小方式的心脏)
2 0
|
2天前
|
存储 编译器 C语言
C语言:字符函数 & 字符串函数 & 内存函数
C语言:字符函数 & 字符串函数 & 内存函数
15 2