docs: added insertion sort (#438)

pull/441/head
Viraj Nirbhavane 2021-08-30 18:24:10 +05:30 committed by GitHub
parent 2d48851620
commit ad6073753a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 42 additions and 1 deletions

View File

@ -1,10 +1,14 @@
# Algorithms
## Sorting
- [Bubble Sort](./Sorting/Bubble-Sort.md)
- [Merge Sort](./Sorting/Merge-Sort.md)
- [Selection Sort](./Sorting/Selection-Sort.md)
- [Insertion Sort](./Sorting/Insertion-Sort.md)
## Strings
- [Palindrome](./Strings/Palindrome.md)
## Searching
@ -12,4 +16,5 @@
- [Binary Search](./Searching/Binary-Search.MD)
## Others
[How to add new algorithm documentation?](./CONTRIBUTING.md)

View File

@ -0,0 +1,36 @@
# Insertion Sort
Inserion sort is an **inplace** sorting algorithm meaning it won't take any extra space to sort the array items. It works similar to the way you sort playing cards in your hand.
Consider you are dealt 4 cards one after the other. You pick one and keep in your hand, after that for the next card (key) you compare with the one in your hand and place it accordingly and so on until all the cards are in your hand.
## Steps
To sort an array of size n in ascending order:
1. Iterate from second element, arr[1] to arr[n-1] over the array.
2. Compare the current element (key) to its predecessor.
3. If the key element is smaller than its predecessor, compare it to the elements before. Move the greater elements one position up to make space for the swapped element.
## Example
Given array is
**12 11 13 5 6 7**
Sorted array is
**5 6 7 11 12 13**
## Implementation
- [Java](../../../algorithms/Java/sorting/insertion-sort.java)
- [C](../../../algorithms/C/sorting/insertion-sort.c)
- [C++](../../../algorithms/CPlusPlus/Sorting/insertion-sort.cpp)
- [JavaScript](../../../algorithms/JavaScript/src/sorting/insertion-sort.js)
- [Python](../../../algorithms/Python/sorting/insertion_sort.py)
## Video URL
[Youtube Video about Insertion Sort](https://www.youtube.com/watch?v=BO145HIUHRg)
## Others
[Wikipedia](https://en.wikipedia.org/wiki/Insertion_sort)