Divide and Conquer Algorithm |
The problem is decomposed into smaller, manageable sub-problems that are first independently solved in an approximate manner and then merged into the final solution. |
[84] |
Hill Climbing |
The algorithm explores the neighboring solutions and picks those with the best properties, so that the algorithm constantly “climbs” toward them. |
[85] |
Greedy Algorithms |
Immediate local improvements are prioritized without taking into account the effect on global optimization. The underlying assumption is that such “greedy” choices will result in an acceptable approximation. |
[86] |
Approximation Algorithms |
Solutions are searched for within provable limits around the optimal solution. The aim is to achieve the maximum efficiency. This is convenient for difficult nondeterministic polynomial time problems. |
[87] |
Local Search Algorithms |
An initial solution is assumed, and it is iteratively improved by exploring the immediate vicinity and making small local modifications. No completely new solutions are constructed. |
[88] |
Constructive Algorithms |
Solutions are built part-by-part from an empty set by adding one building block at a time. The procedure is iterative and uses heuristics for the choice of the building blocks. |
[89] |
Constraint Satisfaction Algorithms |
A set of constraints is defined at the beginning. The solution space is then searched locally, each time applying the constraints until all of them are satisfied. |
[90] |
Branch And Bound Algorithm |
The solution space is systematically divided into smaller sub-problems, the search space is bounded according to problem-specific criteria, and branches that result in suboptimal solutions are pruned and removed. |
[91] |
Cutting Plane Algorithm |
An optimization method solving linear programming problems. It finds the optimal solution by iteratively adding new, additional constraints (cutting planes), thus gradually tightening the region of possible solutions and converging towards the optimum. |
[92] |
Iterative Improvement Algorithms |
Here the goal is to iteratively improve an initially proposed problem solution. Thus, systematic adjustments and improvements are made to the initial set by targeting the predefined objectives. The values may be reordered, retuned or swapped until the desired optimization is complete. |
[93] |