primesieve  7.5
prev_prime.c

Iterate backwards over primes using primesieve_iterator.Note that primesieve_next_prime() runs up to 2x faster and uses only half as much memory as primesieve_prev_prime(). Hence if it is possible to write the same algorithm using either primesieve_prev_prime() or primesieve_next_prime() then it is preferable to use primesieve_next_prime().

#include <primesieve.h>
#include <inttypes.h>
#include <stdio.h>
int main()
{
/* primesieve_skipto(&it, start_number, stop_hint) */
primesieve_skipto(&it, 2000, 1000);
uint64_t prime;
/* iterate over primes from 2000 to 1000 */
while ((prime = primesieve_prev_prime(&it)) >= 1000)
printf("%" PRIu64 "\n", prime);
return 0;
}
primesieve.h
primesieve C API. primesieve is a library for fast prime number generation. In case an error occurs e...
primesieve_free_iterator
void primesieve_free_iterator(primesieve_iterator *it)
Free all memory.
primesieve_iterator
C prime iterator, please refer to iterator.h for more information.
Definition: iterator.h:37
primesieve_prev_prime
static uint64_t primesieve_prev_prime(primesieve_iterator *it)
Get the previous prime.
Definition: iterator.h:92
primesieve_init
void primesieve_init(primesieve_iterator *it)
Initialize the primesieve iterator before first using it.
primesieve_skipto
void primesieve_skipto(primesieve_iterator *it, uint64_t start, uint64_t stop_hint)
Reset the primesieve iterator to start.