首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用Java语言计算m^3 <= Long.MAX_VALUE < (m + 1)^3的整数m?

如何用Java语言计算m^3 <= Long.MAX_VALUE < (m + 1)^3的整数m?
EN

Stack Overflow用户
提问于 2019-06-27 12:30:56
回答 3查看 56关注 0票数 0

我想知道long m这样的m*m*m <= Long.MAX_VALUE && Long.MAX_VALUE < (m + 1)*(m + 1)*(m + 1)

如何计算上述long m

我担心溢出,我一点也不知道溢出。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-06-27 12:47:52

您不需要Java来解决这个问题。

Long.MAX_VALUE == (2^63)-1。如果是n == 2^(63/3) = 2^21,那么n*n*n = 2^63。所以,(m+1) == 2^21,也就是m == (2^21)-1

如果您想编写一些代码来说服自己相信这一点:

代码语言:javascript
复制
    long m = (1L << 21) - 1;
    System.out.println(m*m*m);                  // 9223358842721533951
    System.out.println(m*m*m < Long.MAX_VALUE); // true

    long n = m + 1;
    System.out.println(n*n*n);                  // -9223372036854775808

因此,n*n*n已经明显溢出,因为它的价值是负的。

(请注意,如果结果是正的,甚至大于m*m*m,这将不是它没有溢出的证据。这只是巧合,溢出是如此明显)。

您也可以使用Long.compareUnsigned

代码语言:javascript
复制
// Negative, so m*m*m < Long.MAX_VALUE)
System.out.println(Long.compareUnsigned(m*m*m, Long.MAX_VALUE));

// Positive, so unsigned n*n*n > Long.MAX_VALUE)
System.out.println(Long.compareUnsigned(n*n*n, Long.MAX_VALUE));
票数 3
EN

Stack Overflow用户

发布于 2019-06-27 13:07:49

非常感谢你,c0der。

我可以使用Math.cbrt()函数来得到答案。

我可以用安迪·特纳的方法来确认答案是对的。

long m1 = (long) Math.cbrt((double) Long.MAX_VALUE); System.out.println(m1*m1*m1); m1++; System.out.println(m1*m1*m1);

票数 0
EN

Stack Overflow用户

发布于 2019-06-28 02:32:23

这样可以吗?

代码语言:javascript
复制
long i = 0, j = 1;
while (i*i*i < j*j*j) {
    i++;
    j++;
}
Sytem.out.println(i);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56791070

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档