目录

  • C++求两个整数的最小公倍数(LCM)的方法
    • 方法一:利用最大公约数(GCD)计算
      • 代码实现
    • 方法二:逐次增加法
      • 代码实现
    • 方法三:质因数分解法
      • 代码实现
    • 方法比较
    • 处理大数和特殊情况
    • 改进版GCD方法实现

C++求两个整数的最小公倍数(LCM)的方法

最小公倍数(LCM)是指能够同时被两个数整除的最小的正整数。在C++中,有几种常见的方法可以计算两个整数的最小公倍数。

方法一:利用最大公约数(GCD)计算

这是最常用且高效的方法,基于数学公式:

LCM(a, b) = (a × b) / GCD(a, b)

代码实现

#include <iostream>
#include <algorithm> // 用于std::gcd (C++17及以上)// 计算GCD的函数(如果编译器不支持C++17的std::gcd)
int gcd(int a, int b) {while (b != 0) {int temp = b;b = a % b;a = temp;}return a;
}int lcm(int a, int b) {// 防止乘法溢出,先除以GCDreturn (a / std::gcd(a, b)) * b;// 或者使用自定义的gcd函数:// return (a / gcd(a, b)) * b;
}int main() {int num1, num2;std::cout << "输入两个整数: ";std::cin >> num1 >> num2;std::cout << "LCM(" << num1 << ", " << num2 << ") = " << lcm(num1, num2) << std::endl;return 0;
}

方法二:逐次增加法

这种方法通过逐个测试较大的数的倍数,直到找到能被两个数都整除的数。

代码实现

#include <iostream>int lcm(int a, int b) {int max = (a > b) ? a : b;while (true) {if (max % a == 0 && max % b == 0) {return max;}++max;}
}int main() {int num1, num2;std::cout << "输入两个整数: ";std::cin >> num1 >> num2;std::cout << "LCM(" << num1 << ", " << num2 << ") = " << lcm(num1, num2) << std::endl;return 0;
}

方法三:质因数分解法

将两个数分解质因数,然后取每个质因数的最高幂次相乘。

代码实现

#include <iostream>
#include <map>// 质因数分解函数
std::map<int, int> primeFactors(int n) {std::map<int, int> factors;if (n == 0) return factors;// 处理2的因数while (n % 2 == 0) {factors[2]++;n /= 2;}// 处理奇数因数for (int i = 3; i * i <= n; i += 2) {while (n % i == 0) {factors[i]++;n /= i;}}// 如果剩下的n是质数if (n > 2) {factors[n]++;}return factors;
}int lcm(int a, int b) {if (a == 0 || b == 0) return 0;auto factorsA = primeFactors(a);auto factorsB = primeFactors(b);// 合并两个质因数映射,取每个因数的最大指数for (const auto& pair : factorsB) {if (factorsA[pair.first] < pair.second) {factorsA[pair.first] = pair.second;}}// 计算LCMint result = 1;for (const auto& pair : factorsA) {for (int i = 0; i < pair.second; ++i) {result *= pair.first;}}return result;
}int main() {int num1, num2;std::cout << "输入两个整数: ";std::cin >> num1 >> num2;std::cout << "LCM(" << num1 << ", " << num2 << ") = " << lcm(num1, num2) << std::endl;return 0;
}

方法比较

  1. GCD方法:最有效,时间复杂度为O(log(min(a, b))),推荐使用。
  2. 逐次增加法:简单但效率低,时间复杂度为O(max(a, b)),仅适用于小数字。
  3. 质因数分解法:理论上有用,但实现复杂且效率不如GCD方法,适用于需要质因数分解的场景。

处理大数和特殊情况

在实际应用中,还需要考虑:

  • 处理负数(LCM总是正数)
  • 处理零(任何数与零的LCM是零)
  • 防止整数溢出

改进版GCD方法实现

#include <iostream>
#include <algorithm> // 用于std::gcd
#include <cstdlib>   // 用于absint lcm(int a, int b) {if (a == 0 || b == 0) return 0;// 取绝对值a = std::abs(a);b = std::abs(b);// 防止溢出,先除以GCD再相乘return (a / std::gcd(a, b)) * b;
}int main() {int num1, num2;std::cout << "输入两个整数: ";std::cin >> num1 >> num2;std::cout << "LCM(" << num1 << ", " << num2 << ") = " << lcm(num1, num2) << std::endl;return 0;
}

这种方法是最推荐的,因为它高效、简洁且能处理各种边界情况。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/96806.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/96806.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/96806.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux网络:应用层协议http

前言 虽然我们说&#xff0c;应用层协议是我们程序猿自己定的。但实际上,已经有大佬们定义了一些现成的,又非常好用的应用层协议,供我们直接参考使用.HTTP(超文本传输协议)就是其中之一。 我们之前已经学了UDP与TCP套接字的简单使用&#xff0c;以及讲解了进程间的各种关系&a…

ffmpeg推流测试

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、操作步骤1.测试12.测试2总结前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 环境信息&#xff1a; 摄像头&#xff1a;usb摄像头 &a…

Docker的使用及核心命令

文章目录Docker基础概念镜像管理命令镜像查看和搜索镜像下载和删除镜像构建容器生命周期管理创建和启动容器容器控制命令容器清理容器交互和调试进入容器文件操作日志和监控数据管理数据卷&#xff08;Volume&#xff09;绑定挂载网络管理网络基础操作端口映射Dockerfile和Dock…

考研408计算机网络第36题真题解析(2021-2023)

&#xff08;2023.36&#xff09;在使用 CSMA/CD 协议的环境中&#xff0c;使用截断二进制指数退避算法&#xff0c;来选择重传时机&#xff0c;算法 有如下规定&#xff1a; &#xff08;1&#xff09;基本的退避时间为争用期 2τ&#xff0c;假设某网络具体的争用期为 51.2us…

Asio C++ Library是用来做什么的

hriskohlhoff/asio 是由 Chris Kohlhoff 主导维护的开源 C 库&#xff0c;专注于提供高效、跨平台的异步 I/O 支持&#xff0c;广泛应用于网络编程、并发控制和高性能系统开发。 &#x1f4d8; 项目概述 项目名称&#xff1a;Asio C Library 下载地址&#xff1a;https://down…

ac791的按键ad_channel

每次ad_channel这个参数都要给我一定的迷惑性&#xff0c;让我以为这是通道的数量

机器人巡检与巡逻的区别进行详细讲解和对比

机器人巡检与巡逻的区别进行详细讲解和对比 尽管这两个词经常被混用&#xff0c;但在技术和应用层面上&#xff0c;它们有着本质的区别。核心区别在于&#xff1a;巡检是“深度体检”&#xff0c;而巡逻是“治安巡查”。 以下将从多个维度进行详细讲解和对比。 一、核心概念与目…

先进电机拓扑及控制算法介绍(3)——以“数据”驱动电机实现真正的无模型

1. 背景介绍 之前已经介绍过“无模型预测控制&#xff08;Model-Free Predictive Control/MFPC&#xff09;”中的“无模型预测电流控制&#xff08;Model-Free Predictive Current Control/MFPCC&#xff09;”&#xff0c;可参考下面知乎。 https://zhuanlan.zhihu.com/p/6…

C primer plus (第六版)第十一章 编程练习第5,6题

题目&#xff1a;5&#xff0e;设计并测试⼀个函数&#xff0c;搜索第1个函数形参指定的字符串&#xff0c;在其中查找第2个函数形参指定的字符⾸次出现的位置。如果成功&#xff0c;该函数返指向该字符的指针&#xff0c;如果在字符串中未找到指定字符&#xff0c;则返回空指针…

Altium Designer(AD)PCB丝印批量修改

目录 1 Altium Designer(AD)PCB丝印的字体批量修改 1.1选中所有丝印 1.1.1选中一个丝印:鼠标左键点击 1.1.2查找相似对象:鼠标右键或快捷键N 1.1.3如下图所示丝印被全部选中 1.2丝印字体信息修改 1.2.1打开属性面板——>位置/属性/字体修改 1.2.2丝印字体修改 1.2.…

AI+华为HarmonyOS开发工具DevEco Studio详细安装指南

作者&#xff1a;长江支流 日期&#xff1a;2025-09-13 第一部分&#xff1a;AI工具使用 一、如何使用DeepSeek帮助自己的工作&#xff1f; &#xff08;一&#xff09;提示词 为了与时俱进&#xff0c;充分利用最新技术、提高效率&#xff0c;采用AI生成部分材料&#xf…

【Ambari监控】— API请求逻辑梳理

附录&#xff1a;完整内容和源代码下载请参照 https://doc.janettr.com/ 一、前序章节回忆 我们在前面章节拆解了 Collector 的启动过程&#xff0c;并定位了控制器 TimelineWebServices。 本节聚焦 Collector 对外暴露的 REST 服务&#xff0c;搭建「接口全景图」。 二、接口…

论文阅读 2025-9-13 论文阅读随心记

随便记录一下最近阅读的几篇论文 1. Does DINOv3 Set a New Medical Vision Standard? 第一章 动机 (Motivation) 自然图像领域的成功范式&#xff1a;大型语言模型&#xff08;LLMs&#xff09;和视觉基础模型&#xff08;如 DINO 系列&#xff09;证明&#xff0c;通过自监督…

Avalonia 基础导航实现:从页面切换到响应式交互全指南

在 Avalonia 开发中&#xff0c;导航功能是构建多页面应用的核心需求。Avalonia 无需依赖第三方库&#xff0c;仅通过内置控件与 MVVM 模式即可实现灵活的页面切换。本文将以 “基础导航” 为核心&#xff0c;从 ViewModel 与 View 设计、导航逻辑实现&#xff0c;到样式美化与…

UniApp 分包异步化配置及组件引用解决方案

具体参考微信小程序文档基础能力 / 分包加载 / 分包异步化 一、分包页面组件配置 在 UniApp 的pages.json中&#xff0c;为分包页面&#xff08;或主包如 tabbar 页面&#xff09;配置异步组件时&#xff0c;需同时设置usingComponents和componentPlaceholder&#xff1a; {&…

系统核心解析:深入操作系统内部机制——进程管理与控制指南(一)【进程/PCB】

♥♥♥~~~~~~欢迎光临知星小度博客空间~~~~~~♥♥♥ ♥♥♥零星地变得优秀~也能拼凑出星河~♥♥♥ ♥♥♥我们一起努力成为更好的自己~♥♥♥ ♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥ ♥♥♥如果有什么问题可以评论区留言或者私信我哦~♥♥♥ ✨✨✨✨✨✨个人…

微论-神经网络特征空间的动态聚集,对抗灾难性遗忘的新范式

这是一个非常有趣且富有想象力的理论构想。受陀螺仪启发&#xff0c;我将陀螺仪的“定轴性”与“进动性”原理引入神经网络的特征空间&#xff0c;探讨一种对抗灾难性遗忘的新范式。---### **基于陀螺仪原理的神经网络记忆巩固理论探讨**#### **引言&#xff1a;记忆的流失与稳…

鸿蒙审核问题——折叠屏展开态切换时,输入框内容丢失

文章目录背景解决历程1、无意中发现了眉目2、确定问题原因3、解决办法4、官方文档5、总结背景 奇葩的事情年年有啊&#xff0c;今年特别多。这不今天又遇到了一个奇葩的问题。鸿蒙NextAPP上架AppGallery市场&#xff0c;审核拒了&#xff0c;说是折叠屏手机展开态切换时&#…

前后端分离架构中,Node.js的底层实现原理与线程池饥饿问题解析

在VueJava/.NET的前后端分离架构中&#xff0c;Node.js的底层实现原理与线程池饥饿问题解析 一、架构概述&#xff1a;Node.js的定位与角色 在现代Web开发中&#xff0c;Vue.js作为前端框架与Java/.NET后端结合的架构非常流行。在这种架构中&#xff0c;Node.js通常扮演着两个关…

Django ModelForm:快速构建数据库表单

Django 中的 forms.ModelForm —— 它是 Django 表单系统和 ORM 的一个“桥梁”&#xff0c;能帮助你快速基于 数据库模型&#xff08;Model&#xff09; 自动生成表单&#xff0c;极大减少重复代码。1. 什么是 ModelForm 普通 Form (forms.Form)&#xff1a;完全手写字段&…