- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想实现 Sieve of Eratosthenes算法。前面链接中提供的伪代码是
Input: an integer n > 1
Let A be an array of Boolean values, indexed by integers 2 to n,
initially all set to true.
for i = 2, 3, 4, ..., not exceeding √n:
if A[i] is true:
for j = i^2, i^2+i, i^2+2i, i^2+3i, ..., not exceeding n :
A[j] := false
Output: all i such that A[i] is true.
第一个问题是处理索引。为了简单起见,我所做的只是将索引与数据位置相匹配。我的下图描述了这个问题。
我的代码没有根据上述算法生成素数。这是我的实现
#include <iostream>
#include <vector>
#include <cmath>
int main()
{
int n(30);
std::vector<bool> A;
for( int i(2); i <= n+2; ++i )
A.push_back(true);
for ( int i(2); i <= sqrt(n); ++i ){
if ( A[i] == true ){
int a(0);
for ( int j(i*i); j <= n; j += a*i ){
A[j] = false;
++a;
}
}
}
for ( int i(2); i < A.size(); ++i ){
if ( A[i] == true )
std::cout << i << " ";
}
std::cout << std::endl;
return 0;
}
结果是
2 3 5 7 8 11 13 14 15 17 19 20 21 22 23 26 28 29
为什么我的代码没有产生正确的答案?有什么提示吗?
最佳答案
问题出在这个循环中:
for ( int j(i*i); j <= n; j += a*i ){
A[j] = false;
++a;
}
你应该将 j
增加 i
而没有 a
乘数:
for ( int j(i*i); j <= n; j += i ){
A[j] = false;
}
或者用递增的a
计算j
的新值:
for ( int a(0), j(i*i); j <= n; j = i*i + ++a*i ){
A[j] = false;
}
但不要混合使用这两种方法。
关于c++ - Eratosthenes算法的筛法如何实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41346305/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我有实体: @Entity @Table(name = "CARDS") public class Card { @ManyToOne @JoinColumn(name = "PERSON_I
我正在尝试计算二维多边形的表面法线。我正在使用 OpenGL wiki 中的 Newell 方法来计算表面法线。 https://www.opengl.org/wiki/Calculating_a_S
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 7 年前。 Improve
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我这里有以下 XML: Visa, Mastercard, , , , 0, Discover, American Express siteonly, Buyer Pay
即将发生的 Google 政策变更迫使我们实现一个对话框,以通知欧盟用户有关 Cookie/设备标识符用于广告和分析的情况。我只想向欧盟用户显示此对话框。我不想使用额外的权限(例如 android.p
本文分享自华为云社区《华为大咖说 | 企业应用AI大模型的“道、法、术” ——道:认知篇》,作者:华为云PaaS服务小智。 本期核心观点 上车:AGI是未来5~10年内,每个人都无法回避的技
我有一个与酒精相关的网站,需要先验证年龄,然后才能让他们进入该网站。我使用 HttpModule 来执行此操作,该模块检查 cookie,如果未设置,我会将它们重定向到验证页面。我验证他们的年龄并存储
在欧盟,我们有一项法律,要求网页请求存储 cookie 的许可。我们大多数人都了解 cookie 并同意它们,但仍然被迫在任何地方明确接受它们。所以我计划编写这个附加组件(ff & chrome),它
以下在 C 和/或 C++ 中是否合法? void fn(); inline void fn() { /*Do something here*/ } 让我担心的是,第一个声明看起来暗示函数将被定义
我是一名优秀的程序员,十分优秀!