C++17 中 std::lcm:从入门到精通

文章目录
- 一、引言
- 二、`std::lcm` 的基本概念
- 三、入门示例
- 四、计算多个整数的最小公倍数
- 五、`std::lcm` 的实现原理
- 六、在实际项目中的应用
- 七、注意事项
- 八、总结
一、引言
在 C++ 编程中,处理数学运算时,计算最小公倍数(Least Common Multiple,LCM)是一个常见的需求。C++17 引入了 std::lcm 函数,为开发者提供了一种方便快捷的方式来计算两个或多个整数的最小公倍数。本文将详细介绍 std::lcm 的用法,从基础的入门示例到深入的应用场景,帮助你全面掌握这个函数。
二、std::lcm 的基本概念
最小公倍数是指两个或多个整数公有的倍数中最小的一个。例如,对于整数 4 和 6,它们的公倍数有 12、24、36 等,其中 12 是最小的公倍数。std::lcm 函数就是用来计算这种最小公倍数的工具。
std::lcm 函数定义在 <numeric> 头文件中,其函数原型如下:
// 计算两个整数的最小公倍数
template<class T>
constexpr T lcm(T a, T b);// 计算多个整数的最小公倍数
template<class T, class... Args>
constexpr T lcm(T a, Args... args);
std::lcm 是一个模板函数,支持 int、long、long long 等整数类型,并且是 constexpr 函数,这意味着它可以在编译时进行计算,提高了代码的性能。
三、入门示例
下面是一个简单的示例,展示如何使用 std::lcm 计算两个整数的最小公倍数:
#include <iostream>
#include <numeric>int main() {int num1 = 4;int num2 = 6;int result = std::lcm(num1, num2);std::cout << "The LCM of " << num1 << " and " << num2 << " is: " << result << std::endl;return 0;
}
在这个示例中,我们包含了 <iostream> 和 <numeric> 头文件,定义了两个整数 num1 和 num2,然后调用 std::lcm 函数计算它们的最小公倍数,并将结果输出到控制台。
四、计算多个整数的最小公倍数
std::lcm 不仅可以计算两个整数的最小公倍数,还可以计算多个整数的最小公倍数。以下是一个示例:
#include <iostream>
#include <numeric>int main() {int num1 = 4;int num2 = 6;int num3 = 8;int result = std::lcm(num1, num2, num3);std::cout << "The LCM of " << num1 << ", " << num2 << ", and " << num3 << " is: " << result << std::endl;return 0;
}
在这个示例中,我们调用 std::lcm 函数传入三个整数 num1、num2 和 num3,函数会计算这三个整数的最小公倍数。
五、std::lcm 的实现原理
std::lcm 函数的实现基于数学原理,利用了最大公约数(Greatest Common Divisor,GCD)的概念。最小公倍数和最大公约数之间有如下关系:
[ \text{lcm}(a, b) = \frac{|a \times b|}{\text{gcd}(a, b)} ]
在 C++ 中,std::gcd 函数也定义在 <numeric> 头文件中,用于计算两个整数的最大公约数。std::lcm 函数的实现通常会调用 std::gcd 函数来计算最小公倍数。
六、在实际项目中的应用
在实际项目中,std::lcm 函数可以用于解决各种与时间周期、数据采样等相关的问题。例如,假设有两个定时器,一个定时器的周期是 4 秒,另一个定时器的周期是 6 秒,我们想知道它们何时会同时触发,就可以使用 std::lcm 计算它们的最小公倍数,得到 12 秒,即每隔 12 秒两个定时器会同时触发。
以下是一个简单的代码示例,模拟两个定时器的情况:
#include <iostream>
#include <numeric>class Timer {
public:Timer(int period) : period_(period) {}int getPeriod() const { return period_; }
private:int period_;
};int main() {Timer timer1(4);Timer timer2(6);int lcm_result = std::lcm(timer1.getPeriod(), timer2.getPeriod());std::cout << "The timers will trigger simultaneously every " << lcm_result << " seconds." << std::endl;return 0;
}
七、注意事项
- 输入参数类型:
std::lcm函数是模板函数,支持整数类型。在使用时,确保传入的参数类型是兼容的整数类型,否则可能会导致编译错误。 - 溢出问题:在计算最小公倍数时,由于涉及乘法运算,可能会导致整数溢出。特别是对于较大的整数,需要注意溢出的可能性。
constexpr特性:由于std::lcm是constexpr函数,可以在编译时计算结果。在一些场景中,可以利用这个特性来提高代码的性能,例如在编译时计算数组的大小等。
八、总结
C++17 中的 std::lcm 函数为计算整数的最小公倍数提供了一种简洁高效的方式。通过本文的介绍,你已经了解了 std::lcm 的基本概念、使用方法、实现原理以及在实际项目中的应用。希望这些知识能够帮助你在 C++ 编程中更好地处理数学运算相关的问题。在实际应用中,合理使用 std::lcm 函数,可以提高代码的可读性和性能,使你的程序更加健壮和高效。
相关文章:
C++17 中 std::lcm:从入门到精通
文章目录 一、引言二、std::lcm 的基本概念三、入门示例四、计算多个整数的最小公倍数五、std::lcm 的实现原理六、在实际项目中的应用七、注意事项八、总结 一、引言 在 C 编程中,处理数学运算时,计算最小公倍数(Least Common Multiple&…...
初阶c语言(循环语句习题,完结)
前言: c语言为b站鹏哥,嗯对应视频37集 昨天做的c语言,今天在来做一遍,发现做错了 今天改了平均值的计算, 就是说最大值加上最小值,如果说这个数值非常大的话,两个值加上会超过int类型的最大…...
本地Deepseek-r1:7b模型集成到Google网页中对话
本地Deepseek-r1:7b网页对话 基于上一篇本地部署的Deepseek-r1:7b,使用黑窗口对话不方便,现在将本地模型通过插件集成到Google浏览器中 安装Google插件 在Chrome应用商店中搜索page assis 直接添加至Chrome 修改一下语言 RAG设置本地运行的模型&#…...
SSM课设-学生选课系统
【课设者】SSM课设-学生选课系统 分为 管理员 和 老师 和 学生端 技术栈 前端: HtmlCssJavaScriptAjax 后端: Spring、Spring MVC、MyBatis、MySQL、JSP 学生端 --选课 选课 搜索 --查看选课结果 --退选 --查看已修课程 --管理个人信息 老师端 --添加教学课程 添加 …...
Windows中使用Docker安装Anythingllm,基于deepseek构建自己的本地知识库问答大模型,可局域网内多用户访问、离线运行
文章目录 Windows中使用Docker安装Anythingllm,基于deepseek构建自己的知识库问答大模型1. 安装 Docker Desktop2. 使用Docker拉取Anythingllm镜像2. 设置 STORAGE_LOCATION 路径3. 创建存储目录和 .env 文件.env 文件的作用关键配置项 4. 运行 Docker 命令docker r…...
AI前端开发技能提升与ScriptEcho:拥抱AI时代的前端开发新范式
随着人工智能技术的飞速发展,AI前端开发岗位对技能的要求也水涨船高。越来越多的企业需要具备AI相关知识和高级前端开发能力的工程师,这使得传统的前端开发模式面临着巨大的挑战。如何提升开发效率,降低人力成本,成为了摆在所有前…...
【Redis存在线程安全问题吗?】
Redis存在线程安全问题吗? Redis的线程安全性概述Redis线程安全性的挑战Redis线程安全性的示例示例1:客户端并发访问导致的问题示例2:分布式环境下的问题解决Redis线程安全问题的建议总结Redis的线程安全性概述 Redis本身是一个单线程的键值存储数据库,它使用单线程模型来…...
碎碎念,再聊HyperRAM(CrosslinkNX FPGA+HyperRAM)
作者:Hello,Panda HyperRAM其实熊猫君很久以前在用了,几年前也分享了一篇实现HyperRAM控制器的博文(博文《Lattice CrossLinkNx LIFCL-40应用连载7-使用HyperRAM存储器》。近期在后台收到好几位朋友咨询一些关于HyperRAM的问题&a…...
左移架构 -- 从攒批,湖仓到使用数据流的实时数据产品
编辑导读: 这篇文章翻译自 Kai Waehner的 《The Shift Left Architecture – From Batch and Lakehouse to Real-Time Data Products with Data Streaming》。文章通过数据产品的概念引出了如何创建可重复使用的数据产品使企业能够从当前和未来的数据中获得价值。基于构建数据产…...
多模态识别和自然语言处理有什么区别
在科技飞速发展的当下,人工智能(AI)已经渗透到我们生活的方方面面。不知道大家有没有这样的经历:早上醒来,对着智能音箱说 “播放今天的新闻”,音箱不仅能识别你的语音,还能在播放新闻的同时&am…...
进阶——第十六蓝桥杯嵌入式熟练度练习(串口的小BUG补充-字符接受不完整和字符接受错误)
1.解决接受不完整问题 假如没接受完成,执行函数,就可能会把count直接清零,就会重新接受\ while (1){if(rx_count!0){uint8_t temprx_count;HAL_Delay(1);if(temprx_count)uart_proc(); }key_proc();rxclear_proc();/* USER CODE END WHILE…...
数据结构-链式二叉树
文章目录 一、链式二叉树1.1 链式二叉树的创建1.2 根、左子树、右子树1.3 二叉树的前中后序遍历1.3.1前(先)序遍历1.3.2中序遍历1.3.3后序遍历 1.4 二叉树的节点个数1.5 二叉树的叶子结点个数1.6 第K层节点个数1.7 二叉树的高度1.8 查找指定的值(val)1.9 二叉树的销毁 二、层序…...
【git-hub项目:YOLOs-CPP】本地实现01:项目构建
目录 写在前面 项目介绍 最新发布说明 Segmentation示例 功能特点 依赖项 安装 克隆代码仓库 配置 构建项目 写在前面 前面刚刚实现的系列文章: 【Windows/C++/yolo开发部署01】 【Windows/C++/yolo开发部署02】 【Windows/C++/yolo开发部署03】 【Windows/C++/yolo…...
250213-RHEL8.8-外接SSD固态硬盘
It seems that the exfat-utils package is still unavailable, even after enabling the RPM Fusion repository. This could happen if the repository metadata hasn’t been updated or if the package isn’t directly available in the RPM Fusion repository for RHEL 8…...
如何本地部署DeepSeek?
DeepSeek:智能时代的得力助手 在人工智能技术飞速发展的今天,DeepSeek 作为一款由国内顶尖团队研发的 AI 工具,凭借其卓越的性能和丰富的功能,逐渐在众多同类产品中脱颖而出,成为众多用户在工作和学习中的得力助手。 …...
leetcode:627. 变更性别(SQL解法)
难度:简单 SQL Schema > Pandas Schema > Salary 表: ----------------------- | Column Name | Type | ----------------------- | id | int | | name | varchar | | sex | ENUM | | salary | int …...
51单片机(国信长天)矩阵键盘的基本操作
在CT107D单片机综合训练平台上,首先将J5处的跳帽接到1~2引脚,使按键S4~S19按键组成4X4的矩阵键盘。在扫描按键的过程中,发现有按键触发信号后(不做去抖动),待按键松开后,在数码管的第一位显示相应的数字:从左至右&…...
封装一个sqlite3动态库
作者:小蜗牛向前冲 名言:我可以接受失败,但我不能接受放弃 如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、项目案例 二…...
Transformer以及BERT阅读参考博文
Transformer以及BERT阅读参考博文 Transformer学习: 已有博主的讲解特别好了: 李沐:Transformer论文逐段精读【论文精读】_哔哩哔哩_bilibili知乎:Transformer模型详解(图解最完整版) - 知乎 个人杂想&…...
AI学习记录 - 最简单的专家模型 MOE
代码 import torch import torch.nn as nn import torch.nn.functional as F from typing import Tupleclass BasicExpert(nn.Module):# 一个 Expert 可以是一个最简单的, linear 层即可# 也可以是 MLP 层# 也可以是 更复杂的 MLP 层(active function 设…...
Linux应用开发之网络套接字编程(实例篇)
服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …...
五年级数学知识边界总结思考-下册
目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...
Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器
第一章 引言:语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域,文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量,支撑着搜索引擎、推荐系统、…...
让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...
图表类系列各种样式PPT模版分享
图标图表系列PPT模版,柱状图PPT模版,线状图PPT模版,折线图PPT模版,饼状图PPT模版,雷达图PPT模版,树状图PPT模版 图表类系列各种样式PPT模版分享:图表系列PPT模板https://pan.quark.cn/s/20d40aa…...
学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”
2025年#高考 将在近日拉开帷幕,#AI 监考一度冲上热搜。当AI深度融入高考,#时间同步 不再是辅助功能,而是决定AI监考系统成败的“生命线”。 AI亮相2025高考,40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕,江西、…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...
七、数据库的完整性
七、数据库的完整性 主要内容 7.1 数据库的完整性概述 7.2 实体完整性 7.3 参照完整性 7.4 用户定义的完整性 7.5 触发器 7.6 SQL Server中数据库完整性的实现 7.7 小结 7.1 数据库的完整性概述 数据库完整性的含义 正确性 指数据的合法性 有效性 指数据是否属于所定…...
华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...
基于Java+VUE+MariaDB实现(Web)仿小米商城
仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意:运行前…...
