得到自然数因子

	public static boolean IsPrime(long number) {
int begin = 2;
int end = (int) Math.sqrt(number) + 1;
for (int i = begin; i < end; i++) {
if (number % i == 0)
return false;
for_count1++;
}
return true;
}

// 得到因子
public static Set<Long> getFactor(Long number) {
Set<Long> factors = new HashSet<Long>();
Long begin = 2L;
Long end = number;
for (Long i = begin; i < end&&number!=1; i++) {
if (number % i == 0) {
factors.add(i);
while ((number % i) == 0) {
number = number / i;
for_count1++;
}
}
for_count1++;
}
if (number != 1) {
factors.add(number);
}
return factors;
}

public static Set<Integer> getFactor1(Long number) {
Set<Integer> factors = new HashSet<Integer>();
if (number % 2 == 0) {
factors.add(2);
do {
number = number / 2;
for_count2++;
} while (number % 2 == 0);
}
int i = 3;
do {
if (number % i == 0) {
factors.add(i);
do {
number = number / i;
for_count2++;
}while (number % i == 0);
}
i = i + 2;
for_count2++;
} while (number != 1);

return factors;
}

public static Set<Long> getFactor2(Long number) {
Set<Long> factors = new HashSet<Long>();
if (number % 2 == 0) {
factors.add(2L);
do {
number = number / 2;
for_count3++;
} while (number % 2 == 0);
}
Long i = 3L;
long maxFactor = (long)Math.sqrt(number);
do {
while (number % i == 0) {
factors.add(i);
number = number / i;
for_count3++;
}
i = i + 2;
for_count3++;
} while (number != 1&&i<maxFactor);
if(number!=1){
factors.add(number);
}

return factors;
}


运算结果:
2018的因子
[2, 1009] for_count1:1010
[2, 1009] for_count2:506
[2, 1009] for_count3:15
600851475143的因子
[6857, 71, 839, 1471] for_count1:6860
[6857, 71, 839, 1471] for_count2:3432
[6857, 71, 839, 1471] for_count3:3432
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值