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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 好友朋友圈动态仅三天可见?点击这个按钮,不管多久都能看

    好友朋友圈动态仅三天可见?点击这个按钮,不管多久都能看微信朋友圈可以说是了解好友的最好地方,但是现在大部分人都会设置朋友圈动态仅三天可见的权限。这样就只能看到好友三天内的朋友圈内容,其实只要点击这个按钮,多久都能看!先给大家介绍一点朋友圈小技巧吧!快速设置朋友圈权限朋友圈最烦人的就是广告了,本来想看看好友们有趣的动态,但翻了好几页都是广告。其实只需长按对方头像,就能设置不看对方的权限啦!发表纯文字朋友圈家里…

    2022年6月11日
    101
  • 【原创】异步FIFO设计原理详解 (含RTL代码和Testbench代码)

    【原创】异步FIFO设计原理详解 (含RTL代码和Testbench代码)FIFO在硬件上是一种地址依次自增的SingleDulRAM,按读数据和写数据工作的时钟域是否相同分为同步FIFO和异步FIFO,其中同步FIFO是指读时钟和写时钟为同步时钟,常用于数据缓存和数据位宽转换;异步FIFO通常情况下是指读时钟和写时钟频率有差异,即由两个异步时钟驱动的FIFO,由于读写操作是独立的,故常用于多比特数据跨时钟域处理。本文仅讨论异步FIFO的设计。因为FIFO的硬件本质是一块SingleDulRAM,无论它的内部结构和原理如何复杂,最核心的…

    2022年8月13日
    8
  • 如何判断一个网址是否安全_域名和dns的区别

    如何判断一个网址是否安全_域名和dns的区别前言近几年,互联网发生着翻天覆地的变化,尤其是我们一直习以为常的HTTP协议,在逐渐的被HTTPS协议所取代,在浏览器、搜索引擎、CA机构、大型互联网企业的共同促进下,互联网迎来了“HTTPS加密时代”,HTTPS将在未来的几年内全面取代HTTP成为传输协议的主流。读完本文,希望你能明白: HTTP通信存在什么问题 HTTPS如何改进HTTP存在那些问题 HTTP…

    2022年10月16日
    3
  • 并查集union操作_数据库递归查询语句

    并查集union操作_数据库递归查询语句本文主要介绍解决动态连通性一类问题的一种算法,使用到了一种叫做并查集的数据结构,称为Union-Find。更多的信息可以参考Algorithms 一书的Section1.5,实际上本文也就是基于它的一篇读后感吧。原文中更多的是给出一些结论,我尝试给出一些思路上的过程,即为什么要使用这个方法,而不是别的什么方法。我觉得这个可能更加有意义一些,相比于记下一些结论。

    2025年8月7日
    5
  • scala中map与flatMap浅析

    scala中map与flatMap浅析在函数式语言中,函数作为一等公民,可以在任何地方定义,在函数内或函数外,可以作为函数的参数和返回值,可以对函数进行组合。由于命令式编程语言也可以通过类似函数指针的方式来实现高阶函数,函数式的最主要的好处主要是不可变性带来的。没有可变的状态,函数就是引用透明(Referentialtransparency)的和没有副作用(NoSideEffect)。任何一种函数式语言中,都有map函数与fa

    2022年5月4日
    63
  • git 教程

    git 教程

    2021年10月20日
    41

发表回复

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

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