From 684d69de08997f4f70c8ed7ebb4b9e225f9d5839 Mon Sep 17 00:00:00 2001 From: Gaurav Bhardwaj Date: Thu, 6 Oct 2022 20:53:19 +0530 Subject: [PATCH] chore(JavaScript): add trie implementations algorithm (#863) Co-authored-by: Ming Tsai <37890026+ming-tsai@users.noreply.github.com> --- algorithms/JavaScript/README.md | 4 + .../src/trie/trie-implementation.js | 79 +++++++++++++++++++ 2 files changed, 83 insertions(+) create mode 100644 algorithms/JavaScript/src/trie/trie-implementation.js diff --git a/algorithms/JavaScript/README.md b/algorithms/JavaScript/README.md index 11c9b934..9835c2cb 100644 --- a/algorithms/JavaScript/README.md +++ b/algorithms/JavaScript/README.md @@ -49,3 +49,7 @@ - [Max Heap](src/heaps/max-heap.js) - [Min Heap](src/heaps/min-heap.js) + +## Trie + +- [Trie Implementation](src/trie/trie-implementation.js) diff --git a/algorithms/JavaScript/src/trie/trie-implementation.js b/algorithms/JavaScript/src/trie/trie-implementation.js new file mode 100644 index 00000000..b166aba2 --- /dev/null +++ b/algorithms/JavaScript/src/trie/trie-implementation.js @@ -0,0 +1,79 @@ +/* +A trie (pronounced as "try") or prefix tree is a tree data structure +used to efficiently store and retrieve keys in a dataset of strings. +There are various applications of this data structure, +such as autocomplete and spellchecker. + +Insertion: +Average Case: O(N) +Worst Case: O(N) +Best Case: O(N) + +Deletion: +Average Case: O(N) +Worst Case: O(N) +Best Case: O(N) + +Searching: +Average Case: O(N) +Worst Case: O(N) +Best Case: O(1) + +Space complexity: O(alphabet_size * average key length * N) +*/ + +/* +Create a node that will have two properties — +one is the hash map for storing children. +the other one is for keeping track of the end of the word. +*/ + +class Node { + constructor() { + this.children = {}; + this.isEndWord = false; + } +} + +class Trie { + constructor() { + this.root = new Node(); + } + insert(word) { + let node = this.root; + for (const char of word) { + if (!node.children[char]) { + node.children[char] = new Node(); + } + node = node.children[char]; + } + node.isEndWord = true; + } + search(word) { + let node = this.root; + for (const char of word) { + if (!node.children[char]) { + return false; + } + node = node.children[char]; + } + return node.isEndWord ? true : false; + } + startsWith(prefix) { + let node = this.root; + for (const char of prefix) { + if (!node.children[char]) { + return false; + } + node = node.children[char]; + } + return true; + } +} + +const trie = new Trie(); +trie.insert('datastructures'); +trie.insert('datablock'); +console.log(trie.search('dsa')); // false +console.log(trie.search('datablock')); // true +console.log(trie.startsWith('data')); // true