Skip to content

tabassum-khan/Data-Structures-and-Algorithms

Repository files navigation

Data Structures and Algorithms in Java

This is a complete guide to Interview Preparation. This repository entails some of the most frequently asked Data Structures and Algorithms. It contains the theory as well as popular problems from LeetCode and Cracking the Coding Interview Book.

This may also help, if you're a computer science student who needs to prepare for exams -- or if you're a self-taught programmer who wants to brush up on the theory behind your craft -- this repository will definitely help!

😍 Suggestions and contributions are welcome! 😍


💡 How to use this repository?

The respository can be cloned or be downloaded as a zip file.

Or

You can choose to go through the topics on GitHub itself or if you are feeling a bit fancy, you can easily access the whole Data Structure and Algorithms Database on Notion.


💡 Important Resources

The resources listed below have helped me immensely through this journey.


Data Structures

Linear Data Structures

Hierarchial Data Structures

Hashing


Algorithms

Different problems require the use of different kinds of techniques. A good programmer uses all these techniques based on the type of problem. Some commonly-used techniques are:

  1. Divide and conquer
  2. Randomized algorithms
  3. Greedy algorithms
  4. Dynamic programming
  5. Recursion

Sorting

  1. Basic Sorts

  2. Fast Sorts

  3. Special Purpose Sorts

Searching

Backtracking

Greedy Algorithm


Useful Information

Big O Notation

Big O notation is used to classify algorithms according to how their running time or space requirements grow as the input size grows. On the chart below you may find most common orders of growth of algorithms specified in Big O notation.

Big-O Graph

Source: Big O Cheat Sheet.


Below is the list of some of the most used Big O notations and their performance comparisons against different sizes of the input data.

Big O Notation Computations for 10 elements Computations for 100 elements Computations for 1000 elements
O(1) 1 1 1
O(log N) 3 6 9
O(N) 10 100 1000
O(N log N) 30 600 9000
O(N^2) 100 10000 1000000
O(2^N) 1024 1.26e+29 1.07e+301
O(N!) 3628800 9.3e+157 4.02e+2567

Data Structure Operations Complexity

Data Structure Access Search Insertion Deletion Comments
Array 1 n n n
Stack n n 1 1
Queue n n 1 1
Linked List n n 1 n
Hash Table - n n n In case of perfect hash function costs would be O(1)
Binary Search Tree n n n n In case of balanced tree costs would be O(log(n))
B-Tree log(n) log(n) log(n) log(n)
Red-Black Tree log(n) log(n) log(n) log(n)
AVL Tree log(n) log(n) log(n) log(n)
Bloom Filter - 1 1 - False positives are possible while searching

Array Sorting Algorithms Complexity

Name Best Average Worst Memory Stable Comments
Bubble sort n n2 n2 1 Yes
Insertion sort n n2 n2 1 Yes
Selection sort n2 n2 n2 1 No
Heap sort n log(n) n log(n) n log(n) 1 No
Merge sort n log(n) n log(n) n log(n) n Yes
Quick sort n log(n) n log(n) n2 log(n) No Quicksort is usually done in-place with O(log(n)) stack space
Shell sort n log(n) depends on gap sequence n (log(n))2 1 No
Counting sort n + r n + r n + r n + r Yes r - biggest number in array
Radix sort n * k n * k n * k n + k Yes k - length of longest key

About

Basic Data Structures and Algorithms in Java

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages