为什么它不给我生成前n个素数?
Why it doesn't generate me first n prime numbers?
本文关键字:为什么 更新时间:2023-10-16
你能给我一些帮助吗?我是初学者,我不知道我的程序出了什么问题。它生成我所有数字到 n 不仅仅是素数。为什么?
#include <iostream>
using namespace std;
int main()
{
unsigned int i,n,d;
bool prim;
cout<<"n=";
cin>>n;
for(i=2;i<=n;i=i+1)
{
prim=true;
for(d=2;d<=i/2;d=d+1)
if(i%d==0)
{
prim=false;
break;
}
(prim);
cout<<i<<",";
}
return 0;
}
因为(prim)
if (prim) {
cout << i << ",";
}
附带说明一下:
-
d=d+1
和i=i+1
可以只是d++
和i++
- 您可以在循环中声明变量,例如:
for (int i = 0;
而不是(prim);
使用if(prim)
。其余代码是正确的。
#include <iostream>
using namespace std;
int main()
{
unsigned int i,n,d;
bool prim;
cout<<"n=";
cin>>n;
for(i=2;i<=n;i=i+1)
{
prim=true;
for(d=2;d<=i/2;d=d+1)
if(i%d==0)
{
prim=false;
break;
}
if(prim)
cout<<i<<", ";
}
return 0;
}
您的打印条件不正确。
(prim);cout<<i<<",";
应该是
if(prim) cout<<i<<",";
请注意,您的逻辑打印素数 <= n,而不是前n
素数。
> 你错过了if
:
if (prim) cout << i << ',';
if
语句可以减少一点:
prim && cout<<i<<",";
这是因为逻辑表达式的快捷计算。因此,只有当素数为真时,才会评估cout
。如果为 false,则不会计算cout
因为表达式无论如何都是 false。
次要评论:除数 (d) 可以增加到 floor(sqr(i)),而不是增加到 i/2(更有效)。变量 i 可以从 3 开始并增加 2,因为所有偶数都不是素数(除了 2,它可以打印而不计数......
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?