C++-打印素数直到N
C++ - Printing prime numbers till N
问题说:
您将得到一个整数N
。您需要打印所有素数的序列,直到N
。
我想知道我的代码出了什么问题,建议也会有很大帮助。
#include<iostream>
using namespace std;
int main()
{
int N;
cin >> N;
int u;
for(int i = N; i > 0; i--)
{
u = 0;
for(int j = 2; j < N-1; j++)
{
if(i % j == 0)
{
u = 1;
}
}
if(u == 0)
{
cout << i << " ";
}
}
return 0;
}
首先,为了将来的参考,你可能应该在代码审查时发布它,除非有特定的问题,否则你应该创建一个最小、完整和可验证的帖子。
没有什么本质上的错误,除了你没有检查N>0,这可能会导致一个无限循环,j应该是i而不是N,我认为这会把1打印成素数,但它不是。以下是一些提示:
-
为什么要从N到0?与从2到N相比,这似乎有点违背直觉(你可以跳过1,因为它不是素数(
-
如果你要使用一个标志(
u
(,那么你应该将其设为bool
,强制它为真或假 -
你不需要做一个标志,相反,只要你找到一个除数,就会打印数字,然后像一样打破内部循环
for(j=2; j< N-1; j++){ if(i%j==0){ cout << i << " "; break; } }
-
你不需要让j一直到i,只需要求sqrt(i(,因为任何大于平方t(i(的东西都必须乘以小于平方t(i(的某个数。所以如果i不是素数,那么在sqrt(i(下面一定有一个除数
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 打印数字图案
- Log4cpp:以UTC/GMT时区打印日期
- 如何使用gdb制作一个可以漂亮地打印每个对象的C++函数