# Greedy Algorithms

This lesson introduces the Greedy problem-solving technique.

Greedy is an **algorithmic paradigm** that builds up a solution piece by piece; this means it chooses the next piece that offers the most **obvious** and **immediate benefit**. A Greedy algorithm, as the name implies, always makes the choice that seems to be the best at the time. It makes a *locally-optimal* choice in the hope that it will lead to a *globally optimal* solution.

The problems where the locally-optimal choice leads to a global solution are the best fit for the Greedy technique.

The Greedy method can solve a problem that satisfies the below-mentioned properties:

**Greedy choice property:**A global optimum can be arrived at by selecting a local optimum.**Optimal substructure:**An optimal solution to the problem contains an optimal solution to subproblems.

Greedy algorithms work by *recursively* constructing a set of pieces from the smallest possible constituent parts. **Recursion** is an approach to problem-solving in which the solution to a particular problem depends on solutions to smaller instances of the same problem.

Looking at the animation, we can see that the greedy algorithm just grabs the solution it *thinks* is best—without looking at its consequences. It might work in some cases, especially those where the optimal solution of the subset is the solution for the superset as well.

So, the disadvantage is that it is entirely possible that the most optimal short-term solutions may lead to the worst possible long-term outcome!!

However, the advantage of using a greedy algorithm is that solutions to smaller instances of the problem can be straightforward and easy to understand.

Level up your interview prep. Join Educative to access 80+ hands-on prep courses.