我正在经历03级的euler项目。
这是我的代码,我仍然不明白为什么它不起作用。
这是数学问题吗?
有一个编译,但结果为false。有很多因素,不仅是素数。
有人可以看看吗?
谢谢
BR

    #include <iostream>
    #include <string>
    #include <vector>
    #include <cmath>
    #include <cstdint>
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void facteursden(std::vector<uint64_t>& facteursden, uint64_t number)
{

    uint64_t i = 2;

    for (i = 1; i <= number; ++i) {
        if (number % i == 0) {
            facteursden.push_back(i);
        }
    }
}
//////////////////////////////////////////////
uint64_t factprem(uint64_t n)
{
    uint64_t i = 1;

    for (i = 1; i*i < n; ++i) {
   if (n % i != 0)
 return 1; }
return 0;
}

///////////////////////////////////////////////////////////////////////////
int main()
{

    std::vector<uint64_t> monTableau1;
    facteursden(monTableau1, 49);
uint64_t i = 0;
for (i = 0; i < (uint64_t)monTableau1.size(); ++i) {
if (factprem(monTableau1[i]) == 1) {
std::cout << monTableau1[i] << std::endl; }}

return 0 ;
}

最佳答案

有两个错误

uint64_t factprem(uint64_t n)


1.在for循环中从

i=2


代替我= 1

2.功能应该像这样

uint64_t factprem(uint64_t n)
{
uint64_t i = 1;

for (i = 2; i*i <=n; ++i) {
   if (n % i == 0)
 return 0; }
return 1;
}

08-06 14:07