gpt4 book ai didi

c++ - 循环素数,帮助找错,C++

转载 作者:太空宇宙 更新时间:2023-11-04 14:12:30 24 4
gpt4 key购买 nike

花了几个小时试图找出一个错误,但没有成功:(
解决欧拉问题:http://projecteuler.net/problem=35
看来我的脑袋暂时不工作了

代码没有优化,很抱歉(我在这里做错了什么?)正确答案是 55,我的程序给了我 22

#include "euler.hpp"
#include <algorithm>

int main() {
euler::prime_generator<euler::eratosthenes_sieve> gen;
gen.range(0, 1000000);
unsigned c = 0; // number of circular primes
unsigned p = 0; // number of primes (test)
unsigned prime;
while(prime = gen.nextPrime()) {
p++;
bool ok = true;
std::vector<unsigned> pv = euler::number2vector(prime);
if(pv.size() > 1) {

bool cont = false;
for(unsigned i = 0; i < pv.size(); ++i) {
if(pv[i] % 2 == 0) { cont = true; break; }
}
if(cont) continue;
std::sort(pv.begin(), pv.end());

do {
if(!gen.isPrime(euler::array2number(&pv[0], pv.size()))) {
// was desperate and made this
if(euler::isPrime(euler::array2number(&pv[0], pv.size()))) {
std::cout << prime << " -> " << euler::array2number(&pv[0], pv.size()) << std::endl;
}
else ok = false;
break;
}
} while(std::next_permutation(pv.begin(), pv.end()));

}
if(ok) {
//std::cout << prime << std::endl;
c++;
}
//std::cout << prime << std::endl;
}

std::cout << p << " -> " << c << std::endl;

euler::pause();
}

我使用的几个外部函数

// in class
void range(unsigned lower_bound, unsigned upper_bound) {
m_lower_bound = lower_bound;
primes.resize(upper_bound - lower_bound + 1, true);
for(unsigned i = 0; i < 2 - lower_bound; ++i) primes[i] = false;
for(unsigned i = 2; i <= sqrt(upper_bound - lower_bound); ++i) {
if(primes[i]) {
for(unsigned j = i*i; j <= upper_bound; j += i) {
primes[j] = false;
}
}
}
}
// in the same class
bool isPrime(unsigned number) {
return primes[number - m_lower_bound];
}

// in the same class
unsigned nextPrime() {
for(; next <= m_upper_bound; ++next) {
if(isPrime(next)) return next++ + m_lower_bound;
}
return 0;
}

template <typename T>
T array2number(T * begin, unsigned length) {
T number = 0;
unsigned m = 1;
while(length--) {
number += begin[length] * m;
m *= 10;
}
return number;
}

template <typename T>
std::vector<T> number2vector(T number) {
unsigned l = number_length(number);
std::vector<T> vec(l);
while(l--) {
vec[l] = number % 10;
number /= 10;
}
return vec;
}

提前致谢!

最佳答案

这个问题在SO上已经解决了很多次了。搜索“[c++] 素数欧拉”。

for 循环的终止条件给出了证据:

sqrt(upper_bound - lower_bound)

我在你的文章中找不到 primes[] 的定义。 range 函数访问它,但它不是通过参数提供的,也不是函数内声明的 primes 数组。

你可以通过搜索SO和网络得到很多信息。在发布之前尝试一下。

关于c++ - 循环素数,帮助找错,C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13499451/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com