Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/loiane/javascript-datastructures-algorithms
:books: collection of JavaScript and TypeScript data structures and algorithms for education purposes. Source code bundle of JavaScript algorithms and data structures book
https://github.com/loiane/javascript-datastructures-algorithms
algorithm avl-tree binary-tree data-structures deque dictionary dijkstra-algorithm graph graph-algorithms javascript-algorithms linked-list priority-queue queue quicksort set sorting-algorithms stack tree typescript typescript-algorithms
Last synced: 2 days ago
JSON representation
:books: collection of JavaScript and TypeScript data structures and algorithms for education purposes. Source code bundle of JavaScript algorithms and data structures book
- Host: GitHub
- URL: https://github.com/loiane/javascript-datastructures-algorithms
- Owner: loiane
- Created: 2014-05-23T13:40:54.000Z (over 10 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T10:50:14.000Z (4 months ago)
- Last Synced: 2024-10-29T15:08:06.496Z (4 months ago)
- Topics: algorithm, avl-tree, binary-tree, data-structures, deque, dictionary, dijkstra-algorithm, graph, graph-algorithms, javascript-algorithms, linked-list, priority-queue, queue, quicksort, set, sorting-algorithms, stack, tree, typescript, typescript-algorithms
- Language: TypeScript
- Homepage: https://goo.gl/hrb00r
- Size: 13.5 MB
- Stars: 4,640
- Watchers: 135
- Forks: 1,243
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome - loiane/javascript-datastructures-algorithms - :books: collection of JavaScript and TypeScript data structures and algorithms for education purposes. Source code bundle of JavaScript algorithms and data structures book (TypeScript)
- my-awesome-list - javascript-datastructures-algorithms
- awesome-made-by-brazilians - javascript-datastructures-algorithms
README
Learning JavaScript Data Structures and Algorithms
====================================[data:image/s3,"s3://crabby-images/e7b6a/e7b6a107129cdea2af3d63abb895cb3ea16f110b" alt="Build Status"](https://travis-ci.org/loiane/javascript-datastructures-algorithms)
[data:image/s3,"s3://crabby-images/e0f57/e0f579c3059f05501a4f161655ed939530e569d6" alt="codecov"](https://codecov.io/gh/loiane/javascript-datastructures-algorithms)
[data:image/s3,"s3://crabby-images/51143/51143f84aeb4435993ef4e0a15e2aa6f64ae277b" alt="devDependencies Status"](https://david-dm.org/loiane/javascript-datastructures-algorithms?type=dev)
[data:image/s3,"s3://crabby-images/20cc6/20cc6b46bb93b888ea76f3911a23c5a508981cb1" alt="dependencies Status"](https://david-dm.org/loiane/javascript-datastructures-algorithms)
[data:image/s3,"s3://crabby-images/73aea/73aea41d78b5a1263e24a0b79da2c3e713ee0898" alt="Greenkeeper badge"](https://greenkeeper.io/)Source code of **Learning JavaScript Data Structures and Algorithms** book, third edition.
## List of available chapters:
* 01: [JavaScript: a quick overview](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter01_02)
* 02: [ECMAScript and TypeScript Introduction](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter01_02)
* 03: [Arrays](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter03)
* 04: [Stacks](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter04)
* 05: [Queues and Deques](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter05)
* 06: [LinkedLists](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter06)
* 07: [Sets](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter07)
* 08: [Dictionaries and Hashes](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter08)
* 09: [Recursion](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter09)
* 10: [Trees](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter10)
* 11: [Heap](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter11)
* 12: [Graphs](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter12)
* 13: [Sorting and Searching Algorithms](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter13)
* 14: [Algorithm Design and Techniques](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter14)
* 15: [Algorithm Complexity](https://github.com/loiane/javascript-datastructures-algorithms/tree/third-edition/examples/chapter15)### Third Edition Updates
* Algorithms using ES2015+ (ES6+)
* New data structures and algorithms
* All chapters rewritten and reviewed
* Three (3) new chapters
* Creation of a Data Structures and Algorithms library that can be used in the browser or with Node.js
* Algorithms tested with Mocha + Chai (test code available in `test` directory)
* **TypeScript** version of the source code included (library and tests)## Project Structure
`src/js/index.js` file contains all the data structures and algorithms listed by chapter.
```
|_examples (how to use each data structure and algorithm, organized by chapter)
|_src
|___js (source code: JavaScript version)
|_____data-structures
|_______models (classes used by DS: Node, ValuePair, ...)
|_____others (other algorithms such as palindome checker, hanoi tower)
|___ts (source code: TypeScript version)
|_____data-structures
|_______models
|_____others
|_test (unit tests with Mocha and Chai for src)
|___js (tests for JavaScript code)
|___ts (tests for TypeScript code)
```## Installing and running the book examples With Node
* Install [Node](https://nodejs.org)
* Open terminal/cmd and change directory to this project folder: `cd /Users/.../javascript-datastructures-algorithms` (Linux/Max) or `cd C:/.../javascript-datastructures-algorithms`
* run `npm install` to install all dependencies
* To see the examples, run `http-server html` or `npm run serve`. Open your browser `http:\\localhost:8080` to see the book examples
* Or `cd html/chapter01` and run each javascript file with node: `node 02-Variables`## Running the examples in the browser
* Right click on the html file you would like to see the examples, right click and 'Open with Chrome (or any other browser)'
* Or open the `examples/index.html` file to easily navigate through all examples:
* Demo: [https://javascript-ds-algorithms-book.firebaseapp.com](https://javascript-ds-algorithms-book.firebaseapp.com)
Happy Coding!
## Other editions
| 1st edition | 2nd edition | 3rd edition |
| ------------- |:-------------:|:-------------:|
| data:image/s3,"s3://crabby-images/33635/33635c56c6a9bebc6c2e70bb98397edb088d2672" alt="1st edition" | data:image/s3,"s3://crabby-images/5fdb4/5fdb479c3e8689e079b0e463d55fed572de6d57f" alt="2nd edition" | data:image/s3,"s3://crabby-images/381a2/381a2f9b0a001980beffbb315da6cb3eaa41ac99" alt="3rd edition" |
| [Book link](http://amzn.to/1Y1OWPx)| [Book link](http://amzn.to/1TSkcA1)| [Book link](http://a.co/cbMlYmJ)|Book link - first edition:
- [Packt](https://www.packtpub.com/application-development/learning-javascript-data-structures-and-algorithms)
- [Amazon](http://amzn.to/1Y1OWPx)
- [Chinese version](http://www.ituring.com.cn/book/1613)
- [Korean version](http://www.acornpub.co.kr/book/javascript-data-structure)Book link - second edition:
- [Packt](https://www.packtpub.com/web-development/learning-javascript-data-structures-and-algorithms-second-edition)
- [Amazon](http://amzn.to/1TSkcA1)
- [Chinese version](http://www.ituring.com.cn/book/2029)
- [Brazilian Portuguese version](https://novatec.com.br/livros/estruturas-de-dados-algoritmos-em-javascript/)Book link - third edition:
- [Packt](https://www.packtpub.com/en-us/product/learning-javascript-data-structures-and-algorithms-9781788624947)
- [Amazon](http://a.co/cbMlYmJ)
- [Chinese version](http://www.ituring.com.cn/book/2653)
- [Brazilian Portuguese version](https://novatec.com.br/livros/estruturas-de-dados-algoritmos-em-javascript-2ed/)### Found an issue or have a question?
Please create an [Issue](https://github.com/loiane/javascript-datastructures-algorithms/issues) or [Pull Request](https://github.com/loiane/javascript-datastructures-algorithms/pulls)