白于玉
发表于 2023-6-6 00:03:45
本帖最后由 白于玉 于 2023-6-6 00:06 编辑
def PrimeNumberJudgement(n):
if n in :
return 1
elif n % 2 == 0:
return 0
elif n % 6 not in :
return 0
else:
for i in range(3,int(n**0.5)+1,2):
if n % i == 0:
return 0
return 1
n = 600851475143
factor_list = [] # 质因子列表
while 1:
for f in range(2,int(n**0.5)+1): # 只检查到根号n为止
if n % f == 0: # 若可以除尽
n = n // f # 更新被除数
factor_list.append(f) # 列表添加一个质因子
break
if n == 1:
break
if PrimeNumberJudgement(n) == 1: # 若被除数已经是素数,则结束循环
factor_list.append(n) # 列表添加最后一个质因子
break
print(max(factor_list)) # 输出最大的质因子
墨玖
发表于 2023-6-15 04:34:26
来学习了
大饼弟弟
发表于 2023-6-18 21:52:16
6
twices
发表于 2023-6-19 11:21:43
3
567564523
发表于 2023-6-23 22:49:32
1
歌者文明清理员
发表于 2023-7-3 06:38:33
def getyinshus(n):
return
def isprime(n):
return len(getyinshus(n)) < 3
def getprimeyinshus(n):
return
print(max(getprimeyinshus(600851475143)))
pixie99
发表于 2023-7-7 11:06:38
。
songyazh
发表于 2023-7-8 18:55:41
超纲了, 连做第三道,直接看答案了。贪多不烂,今天就到此结束
gurite
发表于 2023-7-8 19:30:51
{:5_109:}
Ewan-Ahiouy
发表于 2023-7-12 13:03:32
/*
Largest prime factor
The prime factors of 13195 are 5, 7, 13 and 29.
What is the largest prime factor of the number 600851475143 ?
题目翻译:
13195 的质数因子有 5, 7, 13 和 29。
那么请问 600851475143 的最大质数因子是多少?
*/
#include <bits/stdc++.h>
using namespace std;
long long n = 600851475143, ans;
bool iszhi(long long a) {
for (int i = 2; i * i < a; i++) {
if (a % i == 0) return false;
}
return true;
}
int main() {
for (long long i = 2; i * i < n; i++) {
if (n % i == 0 and iszhi(i)) {
if (ans < i) ans = i;
}
}
cout << ans << endl;
return 0;
}
输出6857
Ewan-Ahiouy
发表于 2023-7-12 13:10:45
发现一个更好的解法{:10_250:}
/*
Largest prime factor
The prime factors of 13195 are 5, 7, 13 and 29.
What is the largest prime factor of the number 600851475143 ?
题目翻译:
13195 的质数因子有 5, 7, 13 和 29。
那么请问 600851475143 的最大质数因子是多少?
*/
#include <bits/stdc++.h>
using namespace std;
long long n = 600851475143;
int main() {
for (long long i = 2; i * i < n; i++) {
if (n % i == 0) {
n /= i;
}
}
cout << n << endl;
return 0;
}
雨冷青杉
发表于 2023-7-15 11:12:59
1
猪娃要学习
发表于 2023-7-28 15:12:51
tip:根号
liangxixin
发表于 2023-7-31 10:18:02
1
Ian_Li
发表于 2023-8-7 18:59:42
public static void main(String[] args) {
int res = getSum(600851475143l);
System.out.println(res);
}
private static int getSum(long n) {
int res = 0;
for (long i = 2; i < Math.sqrt(n) + 1; i++) {
if (n % i == 0) {
if (isPrime(n / i)) {
return (int)(n / i);
}
if (isPrime(i)) {
res = (int)i;
}
}
}
return res;
}
private static boolean isPrime(long l) {
for (long i = 2; i <= (long)Math.sqrt(l); i++) {
if (l % i == 0) return false;
}
return true;
}
Ian_Li
发表于 2023-8-7 19:07:42
欧拉计划 发表于 2023-5-29 02:41
出师不捷啊,第三题就出纰漏了!
确实是漏了大的那个因数没有检测是否为质数,刚开始有鱼油指出时我竟 ...
加上检查大的因子是不是也不对呀?
如果n有两个大于Math.sqrt(n)的质数因子a,b;并且a<b
循环的过程中,会先t = b;
再t = a;
最后返回a
Ian_Li
发表于 2023-8-7 19:09:31
还有最后的代码写的,for循环里的i也没用到呀.
import math
n = 600851475143
k = 2
for i in range(0, math.isqrt(n)):
if k >= n:
break
elif n % k == 0:
n = n // k
else:
k = k + 1
print(n)
Ian_Li
发表于 2023-8-7 19:12:16
public static void main(String[] args) {
long res = getSum(600851475143l);
System.out.println(res);
}
private static long getSum(long n) {
long k = 2;
while (k < n) {
if (n % k == 0) {
n = n / k;
} else {
k++;
}
}
return n;
}
xw20010211
发表于 2023-8-18 14:33:47
looklook
nkysp
发表于 2023-8-20 11:56:14
好