如何检查数字是否为C++素数
How to check if a number is prime in C++
对我来说,这段代码看起来是正确的,但是当我运行它时,它给我的所有输出都是"2"。我试过几次,但每次都没有发现任何问题。所以我想知道是否有人不介意查看以下代码让我知道我做错了什么。
#include <iostream>
using namespace std;
bool oddOrEven(int x)
{
int divisor = 2; // initial divisor check
bool boolCheck = true; // initial boolean value set to true, later to check
for(int i = x-1; i >= 2;i--)
{
if(i%divisor == 0)
boolCheck = false;
}
return boolCheck; // returning whether or not the number is prime
}
int main()
{
int num1 = 0;
cout << "Please enter how many numbers you want to check: " << endl;
cin >> num1;
cout << "Prime numbers from 2-" << num1 << endl;
for(int i=num1; i >= 2; i--)
{
if(oddOrEven(i))
cout << i << endl;
}
}
任何帮助将不胜感激,我觉得这可能与我的布尔支票有关,但我不是 100% 什么。
编辑:在发布这个之前,我意识到我没有增加除数,所以我尝试了一下,它仍然没有正确。我改变的只是这个:
for(int i = x-1; i >= 2;i--)
{
if(i%divisor == 0)
boolCheck = false;
divisor = divisor + 1;
}
所以我仍然被困住了,再次感谢任何帮助。
你划分了错误的数字。更改此行
if(i%divisor == 0)
自
if (x % i == 0)
话虽如此,您可能知道您的算法远非最佳。至少您可以立即return false
而不是设置标志。您最多只能检查除数 x
的平方根。您只能检查奇数除数。等等。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话