加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 大数的素数因子化

发布时间:2020-12-15 02:06:16 所属栏目:Java 来源:网络整理
导读:我想找到小于10 ^ 12的大数的素数因子分解. 我得到了这段代码(在 java中): public static ListLong primeFactors(long numbers) { long n = numbers; ListLong factors = new ArrayListLong(); for (long i = 2; i = n / i; i++) { while (n % i == 0) { fa
我想找到小于10 ^ 12的大数的素数因子分解.
我得到了这段代码(在 java中):

public static List<Long> primeFactors(long numbers) {
        long n = numbers;
        List<Long> factors = new ArrayList<Long>();
        for (long i = 2; i <= n / i; i++) {
            while (n % i == 0) {
                factors.add(i);
                n /= i;
            }
        }
        if (n > 1) {
            factors.add(n);
        }
        return factors;
    }

首先,上述算法的复杂性是什么?我很难找到它?

对于素数较大的数字来说,它也会太慢.

是否有更好的算法,或者如何优化这个算法?

解决方法

如果你想对许多大数进行分解,那么你可能最好先找到最多为sqrt(n)的素数(例如使用 Sieve of Eratosthenes).然后你必须只检查那些素数是否是因子而不是测试所有i< = sqrt(n).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读