如何让我的 c++ 程序继续运行?
Posted
技术标签:
【中文标题】如何让我的 c++ 程序继续运行?【英文标题】:How can I make my c++ program to countinue? 【发布时间】:2020-09-08 13:52:32 【问题描述】:我写这篇文章是为了找出哪些 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;
【问题讨论】:
你是什么意思它停止?是否有任何错误消息、SegFault 等? 在您的if
和else
中,您以调用temp()
结束。对我来说,这看起来像是保证了无限递归。
它无论如何都会停止
【参考方案1】:
当 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;
【讨论】:
有什么想法吗?我有货以上是关于如何让我的 c++ 程序继续运行?的主要内容,如果未能解决你的问题,请参考以下文章