令我头疼了一会儿的打印素数问题
首先对于打印素数的逻辑我还是清楚的,
基本逻辑是如果一个数只能被其本身整除,那输出这个数
一开始我也确实就采用了for循环嵌套,但是没有想到break这个问题,运行结果不正确,
输出的数是2233344455555这种(具体是什么给忘了)
后来想到那遇到合数应当跳过,就想到了break,于是解出来了
#include <iostream>
using namespace std;
int PrimeNumber()
{
int i = 0;
int j = 0;
for (i = 1; i < 1000; i++)
{
for (j = 2; j <= i-1; j++)
{
if (i % j == 0)
break;
}
if (j == i)
cout << i << " ";
}
return 0;
}
int main()
{
cout << "输出1000以内的素数:" << endl;
PrimeNumber();
}
12/17
今天重新试验代码的时候,本来想打印1000到2000的素数,于是把代码中的
for (i = 1; i < 1000; i++)
替换成了
for (i = 1000; 1001 < i < 2000; i++)
结果死循环了,编译器提示初始条件不满足循环,在确认了边界条件之后我确信不是逻辑的问题,然后就突然想到是不是语法的问题,于是把代码改成
for (i = 1001; i > 1000 and i < 2000; i++)
就通过了,这才让我意识到java和c++就是会有些细节上的不同,有时候一不注意就踩进坑里了。