- 26
- 0
利用bigInteger实现了一下大数阶乘的算法,实测比直接迭代相乘快一个数量级,但是不知道怎么求时间和空间复杂,想大家帮忙看下。
private static String factorial(int n) {
java.math.BigInteger ans = java.math.BigInteger.valueOf(1);
int bits = 0;
for (int i = 2; i <= n; i++) {
if (Integer.bitCount(i) == 1) {
bits += Integer.numberOfTrailingZeros(i);
continue;
}
// ans = ans.multiply(java.math.BigInteger.valueOf(i));
}
ans = subFactorial(1, n);
return ans.shiftLeft(bits).toString();
}
private static java.math.BigInteger subFactorial(long a, long b) {
if ((b - a) < 10) {
java.math.BigInteger res = java.math.BigInteger.ONE;
for (long i = a; i <= b; i++) {
if (Long.bitCount(i) == 1) {
continue;
}
res = res.multiply(java.math.BigInteger.valueOf(i));
}
return res;
} else {
long mid = a + b >>> 1;
return subFactorial(a, mid).multiply(subFactorial(mid + 1, b));
}
} 0
打赏
收藏
点击回答
您的回答被采纳后将获得:提问者悬赏的 10 元积分
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
