Make sure you know Computer science basic data structures. Also you should be aware of fundamental algorithms.
Once they give you problem, don't start coding. Ask clarifying questions to make sure you understand the problem.
Example:
- Will there be null/empty values on input?
- Will all numbers in a binary tree integers?
Learn Big O. Make sure you give what would be the runtime complexity and memory complexity.
Iterative functions take no extra memory and therefore, memory complexity is constant O(1).
Recursive functions take extra on the stack therefore, memory complexity is lograrithmic O(logn)
- Hash Table
- Linked List
- Stack
- Queue
- Tree
- Tries
- Graphs
- Vectors
- Heaps
- Breadth-first search
- Depth-first search
- Merge sort
Download or clone in local machine. Then run individual file in node console to see the results.
Given a sorted array of integers, return the index of the given key. Return -1 if the key is not found.
Run below script
node .\src\arrays\binary-search.js
Given a large array of integers and a window of size w, find the current maximum value in the window as the window slides through the entire array.
Divide two integers without using '/' (division) or '*' (multiplication) operators.
node .\src\math-and-stats\integer-division.jsTraverse by depth and collect all the numbers. And calculate average also.
Runtime Complexity O(logn) Space Complexity O(logn)
abstract data type (ADT) - ADT is defined as a user point of view of a data type and Does not talk about how exactly it will be implemented.
Data-structure represents how data will be stored in memory.
Arrays can store a fixed number of elements, whereas a collection stores object dynamically so there is no size restrictions it grows and shrinks automatically.
- Insert at the end (push) is efficient.
- Remove from the end (pop) is efficient.
- shift is not efficient as the whole array elements need to be shifted to make the adjustment.
Linked lists are dynamic data structure and memory is allocated at run time. They don't store data contiguously rather they use link to point to other elements.
Performance wise linked lists are slower than arrays because there is no direct access to linked list elements.
Suppose we have an array that contains following five elements 1, 2, 4, 5, 6. We want to insert a new element with value “3” in between “2” and “4”.
You have to copy 1,2 in new array then insert 3 and copy rest of the values. Runtime complexity and memory complexity is very high.
Therefore, we use linked list to store 1-6 and we can easily insert 3 in between 2 and 4.
The linked list is a list of items, called nodes. Nodes have two parts, value part and link part. Value part is used to stores the data. The link part is a reference, which is used to store addresses of the next element in the list.
- Head: Head is a reference that holds the address of the first node in the linked list.
- Nodes: Items in the linked list are called nodes.
- Value: The data that is stored in each node of the linked list.
- Link: Link part of the node is used to store the reference of other node.
class LinkedListNode {
  constructor(data) {
    this.data = data;
    this.next = null;
  }
}Below are the types of LinkedList:
The newly created node will become head of the linked list. · Size of the list is increased by one.
We’re given the pointer/reference to the head of a singly linked list, reverse it and return the pointer/reference to the head of the reversed linked list.
Problem Solving steps
Running program output
Depth First Search (DFS) uses a stack for storing the nodes that it is visiting.
Breadth First Search (BFS) uses a queue for storing the nodes that it is visiting.
A tree has hierarchical data and it has nodes.
- Root: top node of tree is called root and has no parent and has no incoming edges.
- Node: every node has parent ( except root ) and 0 or more children's.
- Edge: used to connect two nodes.
- Path: A path is an ordered list of nodes that are connected by edges.
- Leaf: A leaf node is a node that has no children.
- Height of the tree: The height of a tree is the number of edges on the longest path between the root and a leaf.
- The level of node: The level of a node is the number of edges on the path from the root node to that node.
- Children: Nodes that have incoming edges from the same node to be said to be the children of that node.
- Parent: Node is a parent of all the child nodes that are linked by outgoing edges. - Sibling: Nodes in the tree that are children of the same parent are called siblings.
- Ancestor: A node reachable by repeated moving from child to parent.
If you want to store hierarchical data use Tree.
You should know about Binary Tree and Binary Search Tree.
A binary tree is a type of tree in which each node has at most two children (0, 1 or 2) which are referred as left child and right child.
In Binary Search Tree nodes are:
- The key in the left subtree is less than the key in its parent node.
- The key in the right subtree is greater or equal the key in its parent node.
Trie is a tree, in which we store only one character at each node. This final key value pair is stored in the leaves.
Trie is also suitable for solving partial match and range query problems.
Each node in the heap follows the rule that the parent value is greater than its two children are.
There are two types of the heap data structure:
- Max heap: each node should be greater than or equal to each of its children.
- Min heap: each node should be smaller than or equal to each of its children.
A heap is a useful data structure when you want to get max/min one by one from data.
It is just like a dictionary or key value pair.
Graph represents network. It has Nodes, Vertices and Edges.
- Depth-First Search (DFS)
- Breadth-First Search (BFS)
The DFS algorithm we start from starting point and go into depth of graph until we reach a dead end and then move up to parent node (Backtrack). The stack is used to implement DFS.
In BFS algorithm, a graph is traversed in layer-by-layer fashion. point. The queue is used to implement BFS.
Example: Suppose you have given a tree structure and asked to calculate the average of numbers at each level.
| DFS | BFS | 
|---|---|
| Search from root to the leaf | Search level by level | 
| Uses Stack to sort | Uses Queue to sort | 
| Time complexity: Fast | Time complexity: Slow | 
| Where to use: if you can find at root or leaf, find connected components. | Where to use: Find shortest path,find connected components. When you think you have less data go for it. | 





















