【最小公倍数LCM】通俗理解以及Java代码实现

最小公倍数

    • [什么最小公倍数(Least Common Multiple)](#什么最小公倍数(Least Common Multiple))
    • 最小公倍数计算方法
    • 用代码实现最小公倍数
    • [JAVA练习最小公倍数为 K 的子数组数目(最大公约数法)](#JAVA练习最小公倍数为 K 的子数组数目(最大公约数法))

什么最小公倍数(Least Common Multiple)

最小公倍数(LCM)是指两个或多个整数共有的最小正倍数,即是这些数的公倍数中最小的一个。计算最小公倍数常常用于问题如合并分数、时间单位的转换等。

最小公倍数计算方法

  1. 分解质因数法: 将每个数分解质因数,然后取各数中各质因数的最高次幂,相乘即为最小公倍数。

    例如:计算12和18的最小公倍数。

    • 12的质因数分解为2^2 * 3,18的质因数分解为2 * 3^2。
    • 取各质因数的最高次幂,得到2^2 * 3^2 = 36。
  2. 使用最大公约数: 最小公倍数等于两数乘积除以它们的最大公约数。如果不清楚什么是最大公约数 请移步->最大公约数讲解

    例如:计算15和25的最小公倍数。

    • 15和25的最大公约数为5。
    • 最小公倍数 = (15 * 25) / 5 = 75。

通过这些方法,我们可以计算得到两个或多个数的最小公倍数。

用代码实现最小公倍数

java 复制代码
public int lcm(int m,int n){ //求最小公倍数
        int M = m,N = n;
        while(n != 0){
            int r = m % n;
            m = n;
            n = r;
        }
        return M * N / m;
    }

JAVA练习最小公倍数为 K 的子数组数目(最大公约数法)

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 nums子数组 中满足 元素最小公倍数为 k 的子数组数目。

子数组 是数组中一个连续非空的元素序列。

数组的最小公倍数 是可被所有数组元素整除的最小正整数。

示例 1 :

复制代码
输入:nums = [3,6,2,7,1], k = 6
输出:4
解释:以 6 为最小公倍数的子数组是:
- [3,6,2,7,1]
- [3,6,2,7,1]
- [3,6,2,7,1]
- [3,6,2,7,1]

示例 2 :

复制代码
输入:nums = [3], k = 2
输出:0
解释:不存在以 2 为最小公倍数的子数组。
java 复制代码
class Solution {
  public int subarrayLCM(int[] nums, int k) {
        int num = 0;
        for(int i = 0;i < nums.length;i++){
        	int flag = nums[i];
        	if(flag == k) num++;
	        for (int j = i + 1; j < nums.length; j++) {
                flag = lcm(flag,nums[j]);
				if(flag == k) {
					num++;
				}
                if(flag > k){ //当计算出来的最小公倍数比所给最小公倍数k大时退出内层循环
                    break;
                }
				
			}
        }      
	        return num;   
	    }
    public int lcm(int m,int n){ //求最小公倍数
        int M = m,N = n;
        while(n != 0){
            int r = m % n;
            m = n;
            n = r;
        }
        return M * N / m;
    }
}
相关推荐
算法鑫探3 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
yaoxin5211233 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
WBluuue3 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
NotFound4863 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
木子墨5163 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
Ava的硅谷新视界4 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
rabbit_pro4 小时前
Python调用onnx模型
开发语言·python
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
EQUINOX14 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解
算法
萝卜小白4 小时前
算法实习Day04-MinerU2.5-pro
人工智能·算法·机器学习