In this article, we will study what is a divide and conquer algorithm and will also go through the examples and their python code with output. And lastly, we will learn the advantages, disadvantages, and applications of the divide and conquer algorithm. So, let's get started!
What is a Divide and Conquer Algorithm?
Many useful algorithms are recursive in structure, i.e., to solve the given problem, they call themselves recursively one or more times to deal with closely related sub-problems. These algorithms typically follow a divide-and-conquer algorithm. The divide and conquer algorithm involves three steps at each level of recursion.
- Divide: Break the problem into several sub-problems that are similar to the original problem but smaller,
- Conquer: Solve the sub-problem recursively, and if the sub-problem sizes are small enough, just straightforwardly solve the sub-problems.
- Combine: Combine this solution to create a solution to the original problem
Algorithm Of Divide and Conquer
Consider an arbitrary problem, and let adhoc be a simple algorithm capable of solving the problem. We call adhoc a basic sub-algorithm such that it can be efficient in solving small instances, but its performance on large instances is of no concern.
The time complexity for the divide and conquer algorithm is calculated using the master theorem.
where 'n' is the input size, 'a' is the number of sub-problems in the recursion, and ‘n/b’ is the size of each sub-problem where all sub-problems are assumed to have the same size. We can say that f(n) is the work done outside the recursive call.
Divide and Conquer Algorithm Examples
Divide and conquer approach is widely used to solve many problem statements like merge Sort, quick sort, finding closest pair of points, etc. Below we have mentioned 2 such examples which are most important for any programmer to learn.
Example 1 - Tower of Hanoi problem
Problem Statement: In the Tower of Hanoi problem, you are given N blocks in decreasing order of size on Tower A and you want to move all these blocks to Tower C with the help of Tower B. Remember that you can move only one block at a time and block can never be on top of a smaller block.
Suppose we take some blocks let, N = 3, the process of moving the blocks from Tower A to Tower C would be as given below:
First, move the smallest block to Tower C. This step shows the division of the problem by dividing the number of blocks from N=3 to N=2. Therefore, now we can assume our sub-problem to be moving 2 blocks from Tower A to Tower C.
Then move the middle block to Tower B as given in the figure below. Similar to the above step, we further divided the sub-problem from N=2 to N=1 at the source point.
In this step, we start solving the sub-problems by replacing the smallest block over the middle block in Tower B as given below:
Later, move the biggest block to Tower C from Tower A and move the smallest block to empty Tower A from Tower B.
Lastly, we combine the solution and get the final result by moving the middle block over the biggest block from Tower B to Tower C and moving the smallest block from Tower A to Tower C as shown in the figure below:
Here's the illustration of the solution for Tower of Hanoi
Python Code For A Tower Of Hanoi
Move disk 1 from source A to destination B
Move disk 2 from source A to destination C
Move disk 1 from source B to destination C
Move disk 3 from source A to destination B
Move disk 1 from source C to destination A
Move disk 2 from source C to destination B
Move disk 1 from source A to destination B
Example 2: Find the minimum and maximum elements in an array.
Problem Statement: In this problem, we are given an array of elements and we have to find the minimum and maximum element from the given array. We will solve the given problem by the divide and conquer algorithm. Here, we divide the elements as the first step of the divide and conquer algorithm, find the minimum and maximum elements from the array as conquering the solution and finalize the answer at the end by combining the results.
Python Code For Finding Minimum And Maximum Element In Array
The minimum number in the array is: 1
The maximum number in the array is: 90
Divide and Conquer vs Dynamic Programming Algorithm
Divide and Conquer
It includes 3 steps to reach the solution:
Divide: Dividing the original problem into a smaller sub-problem
Conquer: Solving sub-problem recursively
Combine: Combine the solution of the sub-problem to find a final solution
It includes 4 steps to reach the solution:
Characterizing the structure of an optimal solution
Define the value of an optimal solution recursively
Using the bottom-up algorithm, calculate the value of an optimal solution
Using computed information, construct an optimal solution
It is recursive in nature
It is non-recursive in nature
It recursively works on sub-problems and hence consumes more time
It solves the sub-problem only once, and therefore it consumes less time
It is a top-down algorithm
It is a bottom-up algorithm
Sub-problems are independent in nature
Sub-problems are interdependent in nature
Example: Linear search and Merge sort
Example: Matrix Multiplication
Advantages of Divide and Conquer Algorithm
- The divide and conquer algorithm is easy and effective to solve difficult problems by breaking them into sub-problems
- The divide and conquer algorithm helps to solve the sub-problem independently
- The divide and conquer algorithm makes effective and efficient use of memory caches
- The divide and conquer algorithm is often used in sorting algorithms like merge sort, quick sort, etc
- It is also used in searching algorithms like a linear search and binary search
- The round of control in such an algorithm is very efficient and therefore, it is better to use the divide and conquer algorithm while dealing with floating numbers.
- Divide and conquer algorithms does not require any modifications
Disadvantages of Divide and Conquer Algorithm
- In the divide and conquer algorithm, the recursion of the sub-problem is slow
- For some specific problems, the divide and conquer method becomes complicated in comparison to the iterative method
- The divide and conquer algorithm is used to find min and max
- The divide and conquer algorithm is used in the binary search algorithm
- It is used to find the power of the element
- Divide and conquer is the major algorithm in merge sort and quick sort
- Merge sort is used in selection procedures
- It is used Strassen's algorithm for matrix multiplication
- It is used in karatsuba Algorithm
- Merge sort is used in the cooley-Tukey Algorithm
As we studied, the divide and conquer algorithm has many benefits that make it a very useful and important problem-solving algorithm. It helps to solve difficult problems in 3 simple steps using the top-down algorithm recursively. This basic idea of the divide and conquer algorithm can be related to everyday life with lots of practical applications and hence it is important to learn and understand the divide and conquer algorithm.