如何让我的 C++ 程序继续运行?

How can I make my c++ program to countinue?

我写这篇文章是为了找出哪些 10 位数字是素数,但它在显示大约 20 个数字后就停止了。你能帮我弄清楚哪里出了问题吗?或者建议任何其他来源?这对我很重要,因为这是我的学校项目。

#include <iostream>
#include <string>
#include <windows.h>
using namespace std;
void temp()
{
    static long long n1=9999999999 ;
    long long n2,n3;
    if (n1 <= 1 || n1%2==0|| n1%3==0|| n1%5==0|| n1%7==0|| n1%11==0|| n1%13==0|| n1%17==0|| n1%19==0|| n1%23==0|| n1%29==0|| n1%31==0|| n1%37==0|| n1%41==0|| n1%43==0|| n1%47==0|| n1%53==0|| n1%59==0|| n1%61==0|| n1%67==0|| n1%71==0|| n1%73==0|| n1%79==0|| n1%83==0|| n1%89==0|| n1%97==0)
    {
        std::cout<< n1 << "    not prime\n\n";
        n1--;
        temp();
    }
    else
    {
        n2 = (n1 - 1)/2;
        while (n2 > 1)
        {

            n3 = n1 % n2;
            if (n3 == 0)
            {
                std::cout<< n1 << "    not prime\n\n";
            }
            else
            {
                n2--;
            }
        }
        std::cout<< n1 << "    prime\n\n";
        n1--;
        temp();
    }
}

int main(int argc, char** argv)
{
    temp();
    return 0;
}

当 n1 为 9999999983 时,它会卡在 while 循环中,直到 n2 小于或等于 1

你应该寻找更有效的方法

while (n2 > 1)
    {

        n3 = n1 % n2;
        if (n3 == 0)
        {
            std::cout << n1 << "    not prime\n\n";
            n1--;
            temp();
        }
        else
        {
            n2--;
        }
    }

编辑: 这就是您可以根据自己的情况做的(在这里找到它并根据您的需要进行更改(我找到它 here 并对其进行了一些更改以满足您的需要)

#include <iostream>  
using namespace std;

void check() {
    int n = 9999999999;

        while (n != 0) {

            int i, m = 0, flag = 0;
            m = n / 2;
            for (i = 2; i <= m; i++)
            {
                if (n % i == 0)
                {
                    cout << "Number is not Prime." << endl;
                    flag = 1;
                    break;
                }
            }
            if (flag == 0)
                cout << "Number is Prime." << endl;
            n--;
        }
}

int main()
{
    check();
    return 0;
}