java中的gcd

简介: java中的gcd

java中有很多已经实现的方法,不需要我们额外的处理,即已经有了最优解,其中一个便是gcd(greatest common divisor,最大公约数)。

  • 说明
  • java.math.BigInteger.gcd(BigInteger val) 
  • 示例


// create 3 BigInteger objects
BigInteger bi1, bi2, bi3;
// assign values to bi1, bi2
bi1 = new BigInteger("18");
bi2 = new BigInteger("24");
// assign gcd of bi1, bi2 to bi3
bi3 = bi1.gcd(bi2);
String str = "GCD of " + bi1 + " and " + bi2 + " is " +bi3;
// print bi3 value
System.out.println( str );
  • 结果


GCD of 18 and 24 is 6


  • 力扣相关(6224.最大公因数等于 K 的子数组数目


给你一个整数数组 nums 和一个整数 k ,
请你统计并返回 nums 的子数组中元素的最大公因数等于 k 的子数组数目。
子数组 是数组中一个连续的非空序列。
  • 解答


// gcd暴力求解
import java.math.BigInteger;
class Solution {
  public int subarrayGCD(int[] nums, int k) {
    int count = 0;
    for (int i = 0; i < nums.length; i++) {
      BigInteger gcd = BigInteger.ZERO;
      for (int j = i; j < nums.length; j++) {
        count += (gcd = gcd.gcd(BigInteger.valueOf(nums[j]))).intValue() == k ? 1 : 0;
      }
    }
    return count;
  }
}
目录
打赏
0
0
0
0
0
分享
相关文章
Java求最大公约数
Java求最大公约数
90 0
Java中的位运算
本文介绍了位运算符的基础知识,包括原码、反码、补码的概念,以及常见的位运算符(如移位运算符 `&lt;&lt;`、`&gt;&gt;`、`&gt;&gt;&gt;` 和逻辑运算符 `&`、`|`、`^`、`~`)的使用方法和规则。通过具体的二进制示例,详细解释了这些运算符的工作原理,帮助读者更好地理解位运算在计算机中的应用。
Java中的位运算
Java求最小公倍数
Java求最小公倍数
74 0
Java递归函数
Java递归函数
104 0
Java:找出1000以内所有完数
Java:找出1000以内所有完数
5秒用Java写一个快速排序算法?这个我在行
快速排序是一种非常高效的排序算法,由英国计算机科学家霍尔在1960年提出。它的基本思想是选择一个基准元素将待排序数组分成两部分,其中一部分的所有元素都比基准元素小,另一部分的所有元素都比基准元素大,然后对这两部分再分别进行快速排序,整个排序过程可以递归进行。 这种算法的主要步骤是: 1、 选择一个元素作为基准(pivot)。 2、 把数组分为两部分:一部分包含所有小于基准的元素,另一部分包含所有大于或等于基准的元素。这个过程称为分区(partition)操作。 3、 对这两个子数组进行递归排序
【Java】完数问题
【Java】完数问题
83 0
java202302java学习笔记第十一天-买飞机票和质数1
java202302java学习笔记第十一天-买飞机票和质数1
71 0
java202302java学习笔记第十一天-买飞机票和质数1
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等