@algorithm.ts/sieve-totient
Version:
A linear time algorithm to sieve prime numbers and get the Euler's totient function
101 lines (81 loc) • 2.78 kB
Markdown
<header>
<h1 align="center">
<a href="https://github.com/guanghechen/algorithm.ts/tree/release-2.x.x/packages/sieve-totient#readme">@algorithm.ts/sieve-totient</a>
</h1>
<div align="center">
<a href="https://www.npmjs.com/package/@algorithm.ts/sieve-totient">
<img
alt="Npm Version"
src="https://img.shields.io/npm/v/@algorithm.ts/sieve-totient.svg"
/>
</a>
<a href="https://www.npmjs.com/package/@algorithm.ts/sieve-totient">
<img
alt="Npm Download"
src="https://img.shields.io/npm/dm/@algorithm.ts/sieve-totient.svg"
/>
</a>
<a href="https://www.npmjs.com/package/@algorithm.ts/sieve-totient">
<img
alt="Npm License"
src="https://img.shields.io/npm/l/@algorithm.ts/sieve-totient.svg"
/>
</a>
<a href="#install">
<img
alt="Module Formats: cjs, esm"
src="https://img.shields.io/badge/module_formats-cjs%2C%20esm-green.svg"
/>
</a>
<a href="https://github.com/nodejs/node">
<img
alt="Node.js Version"
src="https://img.shields.io/node/v/@algorithm.ts/sieve-totient"
/>
</a>
<a href="https://github.com/facebook/jest">
<img
alt="Tested with Jest"
src="https://img.shields.io/badge/tested_with-jest-9c465e.svg"
/>
</a>
<a href="https://github.com/prettier/prettier">
<img
alt="Code Style: prettier"
src="https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square"
/>
</a>
</div>
</header>
<br/>
A typescript implementation of the **Linear Sieve** algorithm for primes numbers
and Euler's totient function.
If you are curious about this algorithm, you can visit [here][sieve-totient]
for more details.
## Install
* npm
```bash
npm install --save @algorithm.ts/sieve-totient
```
* yarn
```bash
yarn add @algorithm.ts/sieve-totient
```
* deno
```typescript
import sieveTotient from 'https://raw.githubusercontent.com/guanghechen/algorithm.ts/main/packages/sieve-totient/src/index.ts'
```
## Usage
* Get all prime numbers and totient function values in the range $[2, N)$:
```typescript
import sieveTotient from '@algorithm.ts/sieve-totient'
const [totients, primes] = sieveTotient(10)
// =>
// totients: [0, 1, 1, 2, 2, 4, 2, 6, 4, 6]
// primes: [2, 3, 5, 7]
```
## Related
* [Euler's totient function | Wikipedia](https://en.wikipedia.org/wiki/Euler%27s_totient_function)
* [数论基础之筛法 | 光和尘][sieve-totient]
[homepage]: https://github.com/guanghechen/algorithm.ts/tree/release-2.x.x/packages/sieve-totient#readme
[sieve-totient]: https://me.guanghechen.com/post/math/number-theory/sieve/#heading-%E7%BA%BF%E6%80%A7%E7%AD%9B-2