CS660 Combinatorial Algorithms
Fall Semester, 1996
Intro to Analysis
[To Lecture Notes Index]
San Diego State University -- This page last updated Monday, 02 September, 1996
data:image/s3,"s3://crabby-images/c25ae/c25ae2836336a4139f89a57f1bca8103b581e7e5" alt="----------"
Contents of Intro to Analysis
- References
- Mathematical Analysis of Algorithms
- Model of Computing
- Asymptotic Notation
- Recurrences
Intro to Analysis Slide # 1
Introduction To Algorithms, Corman, Leiserson,Rivest, Chapters 1-4
Reading
Introduction To Algorithms, Corman, Leiserson,Rivest, Chapters 1-4 by
Tuesday Sept. 10
Intro to Analysis Slide # 2
Intro to Analysis Slide # 3
If analysis of algorithms is the answer, what is the question?
Given two or more algorithms for the same task, which is better?
- Under which condition is bubble sort better than insertion sort?
What computing resources does an algorithm require?
- How long will it take bubble sort to sort a list of N items?
Goal of mathematical analysis is a function of the resources required of an
algorithm
On what computer?
Intro to Analysis Slide # 4
What is a Computer?
Random-access machine (RAM)
- Single processor
- Instructions executed sequentially
- Each operation requires the same amount of time
- "Standard" set of operations
Single cost vs. Lg(N) cost
- Time required for basic operation?
-
- 3 + 6
- 1234!
Intro to Analysis Slide # 5
What is an Algorithm?
A finite set of rules which gives a sequence of operations for solving a
specific type of problem.
The set of rules must have the following features.
1) Finiteness
- Must terminate after a finite number of steps
2) Definiteness
- Each step of an algorithm must be precisely defined
- No ambiguous statements allowed
3) Effectiveness
- A human must be able to perform each step using paper and pencil in a
finite amount of time.
4) Input
- Each algorithm has some input.
5) Output
- Each algorithm has some output.
Intro to Analysis Slide # 6
Insertion Sort
| Cost | times |
A[0] = - infinity | data:image/s3,"s3://crabby-images/810cd/810cdd018600dbbb31e19711d263bfa175f2dcc0" alt="" | 1 |
for K = 2 to N do | data:image/s3,"s3://crabby-images/158d2/158d2336f3546ca67d8e096f3b866edc0daaa7f5" alt="" | N |
begin | 0 | N-1 | |
J = K; | data:image/s3,"s3://crabby-images/f0c11/f0c111aeb7f7c65ea3fd6b65a9215995f75ad752" alt="" | N-1 |
Key = A[J] | data:image/s3,"s3://crabby-images/73fc1/73fc1ccc80dbb764b96f5186a7ea1967ceacd23e" alt="" | N-1 |
while Key < A[J-1] do | data:image/s3,"s3://crabby-images/3cc9a/3cc9a5ef775c31ecd26fba1e19985d954b83b5f6" alt="" | data:image/s3,"s3://crabby-images/cbbdd/cbbdddbebb493dde62cbc56da04007279087d2f1" alt="" |
begin | 0 | data:image/s3,"s3://crabby-images/9aa6d/9aa6d18b08a06362ab704b7a0a7099c267e1477b" alt="" |
A[J] = A[J-1]; | data:image/s3,"s3://crabby-images/48185/48185e4372fe9596c39d966819fff14504c73058" alt="" | data:image/s3,"s3://crabby-images/3585d/3585dd7e0f2827632ffb6f231953635680de0591" alt="" |
J = J - 1; | data:image/s3,"s3://crabby-images/6fa55/6fa55358137a57dce4caeea7daee7726b83c8124" alt="" | data:image/s3,"s3://crabby-images/8e271/8e27196670a251ecfffafebf4df102aed4bdbbd4" alt="" |
end while; | data:image/s3,"s3://crabby-images/47d3f/47d3ff867e74f3cfdf249a240bf3dc73d20f4377" alt="" | data:image/s3,"s3://crabby-images/e56a8/e56a88f86b2d8600b4fe33dfc4c2c72a62021420" alt="" |
A[J] = Key; | data:image/s3,"s3://crabby-images/30379/303796bff91447cd4f2482f79d7b5903b4c8a8e8" alt="" | N-1 |
end for; | data:image/s3,"s3://crabby-images/6c4ec/6c4ec1b43c0c0dee1fca694c4c161fe728e07896" alt="" | N-1 |
Intro to Analysis Slide # 7
T(N) = cost of running Insertion Sort
data:image/s3,"s3://crabby-images/9c66d/9c66d80567a97111ccef57d1fc402d3ad63552f8" alt=""
where
-
data:image/s3,"s3://crabby-images/9ec92/9ec921a79e235dfcfe7fae30d317ec6b09b152b0" alt=""
What is
?
Intro to Analysis Slide # 8
Summations
Intro to Analysis Slide # 9
Asymptotically tight bound - Theta
-
data:image/s3,"s3://crabby-images/833d0/833d08d29954a4f0ba791ca256c307d7ab59f045" alt=""
-
data:image/s3,"s3://crabby-images/76e89/76e89eb38dd1abea9a92debed87828e02d460b99" alt=""
Asymptotic upper boundsBig-O
-
data:image/s3,"s3://crabby-images/c7c61/c7c61fd3595fcfdbd3e8ee30bd1f3065bcf533fc" alt=""
-
data:image/s3,"s3://crabby-images/e7cff/e7cff24327038264c835ede914441b65c111894c" alt=""
Little o
-
data:image/s3,"s3://crabby-images/86061/860615a067ec6361b649bbf08f9107b986225379" alt=""
-
data:image/s3,"s3://crabby-images/7e78f/7e78fe2d6262392a8d6205841e78eea131d3eaa0" alt=""
Intro to Analysis Slide # 10
Asymptotic lower bounds
Omega
-
data:image/s3,"s3://crabby-images/be69c/be69cf8216433399eb33c404b0a333ea67781537" alt=""
-
data:image/s3,"s3://crabby-images/ade28/ade28d9554d7dedeea889d1347b83d330b403919" alt=""
Little Omega
-
data:image/s3,"s3://crabby-images/466eb/466eb420c5111b33c0a69c6899d9785c12d200ff" alt=""
-
data:image/s3,"s3://crabby-images/80f9f/80f9f72c8203a607e498d6977f94a0dbe0a33198" alt=""
Intro to Analysis Slide # 11
Common Myths and Errors
- Everyone incorrectly writes:
-
- instead of:
-
-
- or even that there is an n such that
data:image/s3,"s3://crabby-images/45709/457099a92ae6b2557cbb7a3ca104ad1dbc0f1a95" alt=""
- Let f(n) = 2n + 10, and g(n) = n then
-
- f(n) = O(g(n)) but f(n) > g(n)
- Using O( ) when mean
data:image/s3,"s3://crabby-images/43e4e/43e4ea5a4d576ceb4d304ad1cb35af19fbf7a24a" alt=""
Intro to Analysis Slide # 12
Terms
Complexity
- Resources required by the algorithm as a function of the input
size
Worst-case Analysis
- Complexity of an algorithm based on worst input of each size
Average-case Analysis
- Complexity of an algorithm averaged over all inputs of each size
-
Insertion Sort
| Comparisons | Element moves |
| | |
worst case | (N+1)N/2 - 1 | (N-1)N/2 |
average case | (N+1)N/4 - 1/2 | (N-1)N/4 |
Intro to Analysis Slide # 13
Quicksort
Input A - array of keys to be sorted
L - index of left most item in array to be sorted
R - index of right most item in array to be sorted
Output A with A[L], A[L+1], ...,A[R] in order
Quicksort(A: array[1..N]; L,R:integer)
if L < R then
begin
Mid := partition(L, R);
Quicksort(A,L,Mid-1);
Quicksort(A,Mid+1,R);
end;
Intro to Analysis Slide # 14
Partition procedure
Input A - array to be split
Left - index of left most element to be split
Right - index of right most element to be split
partition(A,Left,Right)
begin
L := Left + 1;
R := Right;
Key := A[Left];
repeat
repeat L = L + 1 until A[L] >= Key;
repeat R = R - 1 until A[R] <= Key;
swap(A[L],A[R]);
until R <= L
A[Left] := A[L];
A[L] := A[R];
A[R] := Key;
return R;
end
Intro to Analysis Slide # 15
Recurences for Quicksort
Let Q(N) = time complexity of quicksort on input of size N
data:image/s3,"s3://crabby-images/89566/89566aebf8473215cde237ed7079507190b4237e" alt=""
How to solve for Q(N)?
Methods for solving recurrences
Iteration
Substitution
Master theorem
Intro to Analysis Slide # 16
Master theorem
Theorem 4.1
Let a>= 1 and B > 1 be constants. Let f(n) be a function, and let T(n) be
defined by
- T(n) = aT(n/b) + f(n)
where n/b may be either
or
.
Then:
- if
for some constant
> 0 then
-
data:image/s3,"s3://crabby-images/47993/47993b1c6f1d8d5e1ae556a182b5c790fe702070" alt=""
- if
then
-
data:image/s3,"s3://crabby-images/25a6f/25a6f624304291d7d64afdcd3ec8ee8e6158fe1b" alt=""
- if
for some constant
and if a*f(n/b)<= c*f(n) for some constant c < 1 and all large n, then
-
data:image/s3,"s3://crabby-images/5ee3f/5ee3f4d54630a4a6af80e538797157f15d5c25fb" alt=""
Intro to Analysis Slide # 17
Bubble vs. Insertion Sort
| Worst case | Average case |
Bubble sort | data:image/s3,"s3://crabby-images/5092f/5092f53cfea885721992d4518a24c0ea03b69e33" alt="" | data:image/s3,"s3://crabby-images/52b1a/52b1a52a26068161342b5738eccc493aa5032e0d" alt="" |
Insertion Sort | data:image/s3,"s3://crabby-images/47ed7/47ed70899624228ce385dee66bfd2746466c7cbb" alt="" | data:image/s3,"s3://crabby-images/3c239/3c239df475dd8d9d8932c962c57b4c3f850488d8" alt="" |
Bubble Sort
| Comparisons | Element moves |
worst case | (N-1)N/2 | 3(N-1)N/2 |
average case | (N-1)N/2 | 3(N-1)N/4 |
best case | (N-1)N/2 | 0 |
Insertion Sort
| Comparisons | Element moves |
worst case | (N+1)N/2 - 1 | (N-1)N/2 |
average case | (N+1)N/4 - 1/2 | (N-1)N/4 |
best case | N - 1 | 0 |
Intro to Analysis Slide # 18
Bubble vs. Insertion Sort
Timing Results
Worst Case
N | Bubble | Insertion |
100 | 1 | 1 |
200 | 5 | 3 |
400 | 19 | 11 |
800 | 79 | 42 |
1600 | 317 | 166 |
Average Case
N | Bubble | Insertion |
100 | 1 | 0 |
200 | 3 | 1 |
400 | 14 | 5 |
800 | 56 | 21 |
1600 | 228 | 84 |
What is wrong with this Picture?