当前位置: 首页 > article >正文

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

http://www.kler.cn/a/137441.html

相关文章:

  • conda创建pytorch环境报错
  • 第1关:图的邻接矩阵存储及求邻接点操作
  • Ant Design for Figma设计系统组件库 支持变量 非社区版
  • 【单词】【2019】
  • 申银万国期货通过ZStack Cube信创超融合一体机打造金融信创平台
  • React结合antd5实现整个表格编辑
  • 阿里云服务器公网带宽升级的三种方法
  • 图像处理Sobel 算子
  • SpringMvc请求原理流程
  • docker部署Jenkins
  • 2.5计划任务远程管理
  • C/C++ 语言 ‘ == ‘ 运算符仅适用于算数表达式
  • Go——一、Go语言安装及介绍
  • 大学计算机毕业设计真的很难完成吗?(资源持续更新~~)
  • Java学习day14:权限修饰符,集合(知识点+例题详解)
  • 阿里云ECS服务器如何搭建并连接FTP,完整步骤
  • 图像的傅里叶变换
  • 《算法通关村—进制转换问题处理模板》
  • 基于Android个人理财家庭收支系统uniAPP+vue -hbuiderx-微信小程序vj9n8
  • JOSEF约瑟 数显电压继电器 HYJY-30-02 AC220V 导轨安装