This is an old revision of the document!


2.1 Computational Tractability

Efficiency of algorithms is defined in the terms of the running time and the algorithms must be efficient in their use of other resources as well, especially the amount of space(or memory) they use. To analyze algorithms, we focus on the worst case running time where we look for a bound on the largest possible running time the algorithm could have over all inputs of a given size N, and see how it scales with N. The worst-case analysis is the best used when analyzing algorithms. An efficient algorithm is an algorithm that is platform-independent, instance-independent and has predictive value with respect to increasing input sizes. Such an algorithm must achieve qualitatively better worst-case performance at an analytical level than brute-force search. Suppose for a given algorithm, there are absolute constants c > 0 and d >0 so that on every input of size N, its running time is bounded by cNd primitive computational steps.This means that its running time is at most proportional to N d</sup>. If this running-time bound holds, for some c and d,then the algorithm has a polynomial running time and is called a polynomial-time algorithm. We define an efficient algorithm as an algorithm that has a polynomial running time.

courses/cs211/winter2012/journals/jeanpaul/chapter2section1.1326590660.txt.gz · Last modified: 2012/01/15 01:24 by mugabej
CC Attribution-Noncommercial-Share Alike 4.0 International
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0