C语言例题:输入两个正整数m和n,求其最大公约数和最小公倍数。

C语言例题:输入两个正整数m和n,求其最大公约数和最小公倍数。题目:输入两个正整数m和n,求其最大公约数和最小公倍数。

大家好,又见面了,我是你们的朋友全栈君。

题目:输入两个正整数m和n,求其最大公约数和最小公倍数。

  • 方法一:短除法

理论参考:百度知道

#include <stdio.h>
int main() { 
   
	int m, n;  // 两个输入的数
	int x = 1, y;  // x 是最大公约数,y是最小公倍数
	int i = 2;  // 累乘因子,从 2 开始

    printf("请输入 m 和 n:\n");
 	scanf("%d%d", &m, &n);

	// 将输入的两个数调整位置,m 是较大的那个数,n 是较小的那个数
	if (m < n) { 
   
		m = m + n;
		n = m - n;  // m(m + n) - n(n) = m
		m = m - n;  // m(m + n) - n(m) = n
	}

	if (m % n == 0) { 
     // 两个数成倍数
		printf("最大公约数:%d\n最小公倍数:%d\n", n, m);
	} else { 
     // 不成倍数
	 	// 计算最大公约数
		while (i < n) { 
     // 当累乘因子小于较小值时,继续计算
			if (m % i == 0 && n % i == 0) { 
     // 同时为两个数的乘法因子
				m /= i;
				n /= i;
				x *= i;
			} else { 
   
				i++;
			}
		}
		// 计算最小公倍数
		y = x * m * n;
		printf("最大公约数:%d\n最小公倍数:%d\n", x, y);
	}
}
  • 方法二:遍历法
# include<stdio.h>
int main()
{ 
   
	int m, n;  // 两个输入数
	int x, y;  // x 为最大公约数,y 为最小公倍数
	int min, max;  // max 为两个输入数中,较大的一个,min 为较小的一个
	int i;  // 用于 for 循环遍历
	
	printf("请输入 m 和 n:\n");
	scanf("%d %d", &m, &n);

	min = m > n ? n : m;
	max = m > n ? m : n;

	x = 1;  // 公约数初始化设为 1

	if (max % min == 0) { 
     // 两个数是倍数关系
		printf("最大公约数:%d\n最小公倍数:%d\n", min, max);
	} else { 
     // 不成倍数
		// 寻找最大公约数
		for (i = 1; i <= min; i++) { 
     // 从 1 找到 min
			if (max % i == 0 && min % i == 0) x = i;
		}
		// 寻找最小公倍数
		while (max % m != 0 || max % n != 0) { 
     // 当有一方不能被整除时,继续往后找
			max++;
		}
		y = max;
		printf("最大公约数为:%d\n最小公倍数为:%d", x, y);
	}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145832.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql自定义函数详解_mysql自定义函数详解

    mysql自定义函数详解_mysql自定义函数详解需求:对于数据库中的记录,如果有两条连续的数据的value字段的值相同,则发邮件通知相关人员。需求分析:告警系统里面的告警检查是通过SQL来进行的,一般的SQL实现不了此功能,因此,这里可以通过函数的方式来实现。具体实现如下:1、数据表准备:tb_config_record。新建数据表脚本如下:createtabletb_config_record(idint,statusvarch…

    2025年10月3日
    2
  • 在Linux系统中安装pycharm详解

    在Linux系统中安装pycharm详解1 在官网下载 pycharm 安装包 1 1 进入官网 DownloadPyCh PythonIDEfor 选择 Professional 专业版 直接下载 自己可以选择 pycharm 的不同版本 1 2 进入跳转页面后 出现提示框 点 savefile 1 3 下载完成后 打开安装包下载的位置 2 安装 pycharm2 1 解压文件 2 打开终端 进入 pych

    2025年6月20日
    2
  • 数据库端口号怎么修改_sqlserver查看sa密码

    数据库端口号怎么修改_sqlserver查看sa密码sqlserver端口如果出现问题,会直接影响sqlserver的登录,下面就教您sqlserver端口的更改方法,供您参考,让您不再为sqlserver端口问题而头疼。今天遇到一个问题,sqlserver无法登陆,到Services里看,服务没有起来。但是在启动Service时遇到问题说无法启动。去AdministrativeTools->EventViewer中查看了一下,…

    2022年8月31日
    3
  • mvc与三层结构终极区别[通俗易懂]

    mvc与三层结构终极区别[通俗易懂]注:本文章内所有内容都来自互联网,本人主要是起了一个收集的作用http://www.cnblogs.com/zhhh/archive/2011/06/10/2077519.html又看到有人在问三层架构和MVC的关系,感觉这种问题有点教条化了。因为它们都在逻辑上将应用程序划为三块,凑了一个数字3,就有人非要把它们联系到一起了。  这两个东西我接触有几年了,有一点体会,表达一下:

    2022年6月25日
    20
  • 梯度下降法和随机梯度下降法的区别_梯度下降法的优缺点

    梯度下降法和随机梯度下降法的区别_梯度下降法的优缺点1.梯度  在微积分里面,对多元函数的参数求∂偏导数,把求得的各个参数的偏导数以向量的形式写出来,就是梯度。比如函数f(x,y),分别对x,y求偏导数,求得的梯度向量就是(∂f/∂x,∂f/∂y)T,简称gradf(x,y)或者▽f(x,y)。对于在点(x0,y0)的具体梯度向量就是(∂f/∂x0,∂f/∂y0)T.或者▽f(x0,y0),如果是3个参数的向量梯度,就是(∂f/∂x,…

    2025年10月18日
    3
  • 局域网arp断网攻击怎么解决_arp断网攻击连不上网

    局域网arp断网攻击怎么解决_arp断网攻击连不上网   关于局域网断网攻击,顾名思义,就是对局域网内某个IP或全部IP进行攻击,让局域网内某个IP或全部IP断网,这是不是很有趣。   原理:关于arp断网攻击是基于arp协议的缺陷,这其实是arp欺骗的时候配置错误引起的现象。就是以…

    2022年10月7日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号