C++ 如何制作我的c++;程序要继续吗?
我写这篇文章是为了找出哪些10位数字是素数,但它在显示了大约20个数字之后就停止了。你能帮我弄清楚怎么了吗?或者暗示其他来源?这对我很重要,因为这是我的学校项目C++ 如何制作我的c++;程序要继续吗?,c++,windows,console,dev-c++,C++,Windows,Console,Dev C++,我写这篇文章是为了找出哪些10位数字是素数,但它在显示了大约20个数字之后就停止了。你能帮我弄清楚怎么了吗?或者暗示其他来源?这对我很重要,因为这是我的学校项目 #include <iostream> #include <string> #include <windows.h> using namespace std; void temp() { static long long n1=9999999999 ; long long n2,n3;
#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;
}
#包括
#包括
#包括
使用名称空间std;
void temp()
{
静长长n1=9999999;
长n2,n3;
如果(n1当n1为99999983时,它会卡在while循环中,直到n2小于或等于1
你应该寻找一种更有效的方法
while (n2 > 1)
{
n3 = n1 % n2;
if (n3 == 0)
{
std::cout << n1 << " not prime\n\n";
n1--;
temp();
}
else
{
n2--;
}
}
while(n2>1)
{
n3=n1%n2;
如果(n3==0)
{
std::难道你说它停止是什么意思?任何错误消息,SegFault或诸如此类吗?在你的if
和else
中,你都通过调用temp()
来结束。对我来说,这看起来像是保证无限递归。它停止了。你知道吗?我有存货了
#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;
}