summaryrefslogtreecommitdiffhomepage
path: root/docs
diff options
context:
space:
mode:
authorTyge Løvset <[email protected]>2021-03-30 09:11:34 +0200
committerTyge Løvset <[email protected]>2021-03-30 09:11:34 +0200
commit4a06fde5c006b609f910474949b9e097ec8479c8 (patch)
tree2a0dff0fddfa058e0aff1ddb5cde7179e6f47685 /docs
parentc8a7b59dcc8a1d6cd7bf5f5bc6b76f26a97b34d6 (diff)
downloadSTC-modified-4a06fde5c006b609f910474949b9e097ec8479c8.tar.gz
STC-modified-4a06fde5c006b609f910474949b9e097ec8479c8.zip
Another minor fix in cbits.h. Improved cbits_api.md example.
Diffstat (limited to 'docs')
-rw-r--r--docs/cbits_api.md46
1 files changed, 25 insertions, 21 deletions
diff --git a/docs/cbits_api.md b/docs/cbits_api.md
index e4b60da6..006ce52a 100644
--- a/docs/cbits_api.md
+++ b/docs/cbits_api.md
@@ -64,40 +64,44 @@ void cbits_xor(cbits *self, cbits other); // set of disjoint
```c
#include <stc/cbits.h>
#include <stdio.h>
+#include <math.h>
+#include <time.h>
-static inline cbits sieveOfEratosthenes(size_t n)
+cbits sieveOfEratosthenes(size_t n)
{
- cbits primes = cbits_with_size(n + 1, true);
- cbits_reset(&primes, 0);
- cbits_reset(&primes, 1);
-
- c_forrange (i, size_t, 2, n+1) {
- // If primes[i] is not changed, then it is a prime
- if (cbits_test(primes, i) && i*i <= n) {
- c_forrange (j, size_t, i*i, n+1, i) {
- cbits_reset(&primes, j);
+ cbits bits = cbits_with_size(n>>1, true);
+ size_t q = (size_t) sqrt(n);
+
+ for (size_t i = 3; i <= q; i += 2) {
+ for (size_t j = i; j < n; j += 2) {
+ if (cbits_test(bits, j>>1)) {
+ i = j;
+ break;
}
}
+ for (size_t j = i*i; j < n; j += i*2)
+ cbits_reset(&bits, j>>1);
}
- return primes;
+ return bits;
}
int main(void)
{
- int n = 100000000;
- printf("computing prime numbers up to %u\n", n);
+ size_t n = 100000000;
+ printf("computing prime numbers up to %zu\n", n);
- cbits primes = sieveOfEratosthenes(n);
- puts("done");
+ clock_t t1 = clock();
+ cbits primes = sieveOfEratosthenes(n + 1);
+ size_t nprimes = cbits_count(primes);
+ clock_t t2 = clock();
- size_t np = cbits_count(primes);
- printf("number of primes: %zu\n", np);
+ printf("number of primes: %zu, time: %f\n", nprimes, (float)(t2 - t1)/CLOCKS_PER_SEC);
- printf("2 ");
- c_forrange (i, int, 3, 1001, 2) {
- if (cbits_test(primes, i)) printf("%d ", i);
- }
+ printf(" 2");
+ for (size_t i = 3; i < 1000; i += 2)
+ if (cbits_test(primes, i>>1)) printf(" %zu", i);
puts("");
+
cbits_del(&primes);
}
```