From a25ec0ac565be39e77305aa7eea1af1f49bc78da Mon Sep 17 00:00:00 2001 From: Goncalo Nascimento <68239512+Gigolino2001@users.noreply.github.com> Date: Wed, 22 Sep 2021 20:44:44 +0100 Subject: [PATCH] docs: add quick sort (#472) --- docs/en/README.md | 1 + docs/en/Sorting/Quick-Sort.md | 59 +++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+) create mode 100644 docs/en/Sorting/Quick-Sort.md diff --git a/docs/en/README.md b/docs/en/README.md index 3d3f0fc0..2d68cec6 100644 --- a/docs/en/README.md +++ b/docs/en/README.md @@ -7,6 +7,7 @@ - [Selection Sort](./Sorting/Selection-Sort.md) - [Insertion Sort](./Sorting/Insertion-Sort.md) - [Heap Sort](./Sorting/Heap-Sort.md) +- [Quick Sort](./Sorting/Quick-Sort.md) ## Strings diff --git a/docs/en/Sorting/Quick-Sort.md b/docs/en/Sorting/Quick-Sort.md new file mode 100644 index 00000000..eb30c518 --- /dev/null +++ b/docs/en/Sorting/Quick-Sort.md @@ -0,0 +1,59 @@ +# Quick Sort + +1. **Time Complexity:** O(n^2) occurs when the picked pivot is always an extreme (smallest or largest) element. +2. **Space Complexity:** O(n). +3. **Applications:** Commercial computing, search for information, operations research, event-driven simulation, numerical computations, combinatorial search. +4. **Founder's Name:** Tony Hoare + +## Steps + +1. Consider the last element of the list as pivot. +2. Define two variables i and j. Set i and j to first and last elements of the list. +3. Increment i until list[i] > pivot then stop. +4. Decrement j until list[j] < pivot then stop. +5. If i < j then exchange list[i] and list[j]. +6. Repeat steps 3,4 and 5 until i > j. +7. Exchange the pivot element with list[j] element. + +## Example + +**Given array : [10, 80, 30, 90, 40, 50, 70]** + +**Pivot (last element) : 70** + +**1. 10 < 70 then i++ and swap(list[i],list[j]):** [10, 80, 30, 90, 40, 50, 70] + +**2. 80 < 70, then no actions needed:** [10, 80, 30, 90, 40, 50, 70] + +**3. 30 < 70 then i++ and swap(list[i],list[j]):** [10, 30, 80, 90, 40, 50, 70] + +**4. 90 < 70, then no actions needed:** [10, 30, 80, 90, 40, 50, 70] + +**5. 40 < 70 then i++ and swap(list[i],list[j]):** [10, 30, 40, 90, 80, 50, 70] + +**6. 50 < 70 then i++ and swap(list[i],list[j]):** [10, 30, 40, 50, 80, 90, 70] + +**7. Swap list[i+1] and pivot:** [10, 30, 40, 50, 70, 90, 80] + +**8. Quick sort the left part of the pivot:** [10, 30, 40, 50] + +**9. Quick sort the right part of the pivot:** [70, 80, 90] + +**10. Sorted Array:** [10, 30, 40, 50, 70, 80, 90] + + +## Implementation + +- [Java](../../../algorithms/Java/sorting/quick-sort.java) +- [JavaScript](../../../algorithms/JavaScript/src/sorting/quick-sort.js) +- [Go](../../../algorithms/Go/sorting/quicksort.go) +- [C++](../../../algorithms/CPlusPlus/Sorting/quick-sort.cpp) +- [Python](../../../algorithms/Python/sorting/quicksort.py) + +## Video URL + +[Youtube Video about Quick Sort](https://www.youtube.com/watch?v=PgBzjlCcFvc&ab_channel=GeeksforGeeks) + +## Others + +[Wikipedia](https://en.wikipedia.org/wiki/Quicksort)