- Sort problem is obvious to all
- Several distinct algorithms to solve it
- Algorithms use different data structures
- Algorithm performance varies widely
- See Chapters 1, 2, and 7
- For now, skip ShellSort and QuickSort
- Bubble Sort
- Insertion Sort
- Merge Sort
- And analysis as we go…
BubbleSort
procedure BubbleSort( var A : InputArray; N : int);
var
j, P : integer;
begin
for P := N to 2 by -1 do begin
for j := 1 to P - 1 do begin
if A[ j ] > A[ j + 1 ] then
Swap( A[ j ], A[ j + 1 ] );
end; {for}
end; {for}
end;
Template BubbleSort class
template<class T> class CBubbleSort {
public:
void Sort(T *A, int N)
{
for(int P = N-1; P >= 1; P--)
{
for(int j = 0; j<=P-1; j++) { if(A[j + 1] < t =" A[j">Utilizing it…
// Data …
vector<double> data;
// fill in the data…
// Instantiate the sort object…
CBubbleSort<double> sort;
sort.Sort(&data[0], data.size());
Running time for BubbleSort
How many times does c,d get executed?
for P := N to 2 by -1 do begin
for j := 1 to P - 1 do begin
if A[ j ] > A[ j + 1 ] then
Swap( A[ j ], A[ j + 1 ] );
end; {for}
end; {for}
Running time for BubbleSort
How many times does c,d get executed?
data:image/s3,"s3://crabby-images/8f26a/8f26a5c0ee1910f13da86bc15479413b2b50bcf5" alt=""
So, we could say:
data:image/s3,"s3://crabby-images/2c577/2c577ec8bc9d0b345a491ad6928474a59efa727a" alt=""
Big-Oh notation
Definition: T(N)=O( f(N) ) if there are positive constants c and n0 such that T(N) <= cf(N) when N >= n0
Another notation:
data:image/s3,"s3://crabby-images/a026d/a026d00deaed04e7c7a6463ec097c971f6de95b5" alt=""
Intuitively what does this mean?
Asymptotic Upper Bound
data:image/s3,"s3://crabby-images/3a159/3a159b529f2c0a6fc05658aeafee90d4ba053e72" alt=""
Example of Asymptotic Upper Bound
data:image/s3,"s3://crabby-images/9cfde/9cfde5dc5744cb6c27876c238aa31e301fcd6607" alt=""
data:image/s3,"s3://crabby-images/33c3d/33c3d3ec6deb5f3b0eee964db64fd5a961789d04" alt=""
Is BubbleSort O(N2)?
data:image/s3,"s3://crabby-images/25f82/25f8265a27b55f7371fa12703021f681581aaa97" alt=""
data:image/s3,"s3://crabby-images/9be45/9be453c133e3687ca8578562f171e243b3a0cc19" alt=""
Some rules to simplify things…
- Loops:
- Running time is body time times # iterations
- Nested loops:
- Analysis from the inside out…
- Statements:
- Assume time of 1 each
- Unless the statement is an algorithm
- So, we could say:
data:image/s3,"s3://crabby-images/410f2/410f2b96ded2403f87431dff1b6edabfde94d0cd" alt=""
data:image/s3,"s3://crabby-images/1b39a/1b39a50610b74cccb667698965b3c6cada6b0e49" alt=""
Usage
data:image/s3,"s3://crabby-images/5e3ae/5e3ae6e4f5774cb9afbb40ab6d688d2825fd0b46" alt=""
Exercise in Big O-notation
data:image/s3,"s3://crabby-images/bf115/bf11518190da7423bbb63a03cfea0d43f5edb6de" alt=""
What’s the minimum time?
data:image/s3,"s3://crabby-images/81a2c/81a2c7bd7f51fd066eae194dbe302f68ca534df6" alt=""
Omega notation
data:image/s3,"s3://crabby-images/6da67/6da67b28659426500dee307c233edc555a5d3b7f" alt=""
data:image/s3,"s3://crabby-images/8c3be/8c3bea363622264d59b9dae8057180675b26a86c" alt=""
data:image/s3,"s3://crabby-images/d04fc/d04fc9a2834e42162539c6799f9e3ec570c79140" alt=""
data:image/s3,"s3://crabby-images/55775/55775cd9cb94bebaab8f3a0e9135cfefcc75879e" alt=""
Asymptotic Lower Bound
data:image/s3,"s3://crabby-images/4938a/4938a05854f03d906fe7636650a505f28e5b3023" alt=""
What these tell us
What about the “constants”?
- Algorithm 1: O(N), actual time is:
- T(N)=1,000,000N
- Algorithm 2: O(N2), actual time is:
- T(N)=10N2
- When is algorithm 2 faster?
Why do we care?
- After all, computers just keep getting faster, don’t they?
- Is today’s slow algorithm acceptable tomorrow?
- Algorithm 1: O(N2)
- Algorithm 2: O(N)
- If your computer is suddenly 10 times faster, can you handle 10 times as much data in the same time?
Faster Computer or Algorithm?
√ What happens when we buy a computer 10 times faster?
data:image/s3,"s3://crabby-images/548e7/548e702d82d42af3624edacf05ca39293e841079" alt=""
Constant running time
data:image/s3,"s3://crabby-images/295c5/295c5658f7dbfbd23165f8205be5662456f61e94" alt=""
Theta Notation
data:image/s3,"s3://crabby-images/b6928/b6928fefcc04c1315db60acf8868fa2649c9778d" alt=""
Big O, Omega, Theta
data:image/s3,"s3://crabby-images/ada43/ada43325cc56e46e3115bdce9e7e8c79c2694d2a" alt=""
In general:
O is used to denote the upper bound of the complexity
Ω is used to denote the lower bound of the complexity
Ø is used to denote the tight bound of the complexity
Example, the general sorting problem has the time complexity Ω(nlogn). Any sorting based on compare-interchange takes c.nlogn time for some constant c.
Sorting problem has a time complexity O(nlogn)
(since there is an algorithm which sorts in O(nlogn) time)
Aside: Can we make this faster in some cases?
procedure BubbleSort( var A : InputArray; N : int);
var
j, P : integer;
begin
for P := N to 2 by -1 do begin
for j := 1 to P - 1 do begin
if A[ j ] > A[ j + 1 ] then
Swap( A[ j ], A[ j + 1 ] );
end; {for}
end; {for}
end;
Insertion Sort
procedure InsertionSort( var A : InputArray; N : integer);
var j, P : integer; Tmp : InputType;
begin
for P := 2 to N do begin
j := P;
Tmp := A[ P ];
while j > 1 and Tmp < A[ j - 1 ] do begin
A[ j ] := A[ j - 1 ];
j := j - 1;
end; {while}
A[ j ] := Tmp;
end; {for}
end;
Worst case analysis
- N outer loops
- Each item moved maximum distance
- For item i, that would be i-1, right?
data:image/s3,"s3://crabby-images/f7f16/f7f168e411a1a06a8e07ad42dfa35b68a1d026a3" alt=""
Best case analysis
- N outer loops
- Each is not moved at all
- For item i, 0 moves, which is constant time.
data:image/s3,"s3://crabby-images/a9bc2/a9bc2126c577297957b9c3d4887195feec3a3869" alt=""
Worst-Case and Average-Case Analysis
- Worst-case analysis
- Big O, the upper bound, of the running time of any input of size N.
- Average-case analysis
- Some algorithms are fast in practice.
- The analysis is usually much harder.
- Need to assume that all input are equally likely.
- Sometimes, it is not obvious what is the average.
InsertionSort Average Case
data:image/s3,"s3://crabby-images/a06c7/a06c71541032e9ecb4c06f7c9930eabff6aef9e6" alt=""
Insertion Sort Average CaseMore formal solution
- For sorting, we assume randomly ordered data.
- Inversions:
- An inversion in an array of numbers is any ordered pair (i, j) having the property that
- i < j and A[i] > A[j]
- How many inversions in this list:
- 12, 17, 5, 7, 21, 1, 8
- How many are possible altogether?
Inversions
√ The maximum inversions for a list of size N is N(N-1)/2
√ Theorem: The average number of inversions in an array of N distinct numbers is N(N-1)/4
Average case for exchanging adjacent elements
√ When we exchange adjacent elements we remove exactly one inversion
- 12, 17, 5, 7, 21, 1, 8
Mergesort
procedure MergeSort( var A : InputArray; N : int);
Begin
MSort(A, 1, N)
end;
Procedure MSort(var A : InputArray; F, L : int);
var q: int;
Begin
if F < L then begin
q := (F + L) / 2
MSort(A, F, Q);
MSort(A, Q+1, L);
Merge(A, F, Q, L);
end;
End;
data:image/s3,"s3://crabby-images/9327d/9327dd952744db5c38436aa6f660f33d90557b4f" alt=""
How long does merge take?
data:image/s3,"s3://crabby-images/c8724/c8724fda8702842da33aa6eba6a3c50e3346b5cc" alt=""
- One of the earliest sorting sorting algorithms, invented by John von Neumann in 1945.
- Mergesort is Divide-and-conquer Algorithm
- Given an instance of the problem to be solved, split this into several, smaller, sub-instances (of the same problem) independently solve each of the sub-instances and then combine the sub-instance solutions so as to yield a solution for the original instance.
- The problem is divided into smaller problems and solved recursively.
- Quicksort and heapsort are also such algorithms
data:image/s3,"s3://crabby-images/b18c7/b18c7818b2c63da7b2c511125eb7ab837c4b9904" alt=""
Running Time
Mergesort
- O(n log n) worst-case running time
- Same ops done regardless of input order
- Mergesort is Divide-and-conquer Algorithm
- Copying to and from temporary array
- Extra memory requirement
- Extra work
data:image/s3,"s3://crabby-images/9c014/9c0145eca49cd549cd686370c9c07c27413abf51" alt=""
data:image/s3,"s3://crabby-images/f20a3/f20a3e05c9f0b6e0f8c9a0feae401d4436bcc132" alt=""
data:image/s3,"s3://crabby-images/a8e11/a8e112d9b8b9596b1d2a4ad0f461c7fce847f65b" alt=""
data:image/s3,"s3://crabby-images/10a6f/10a6fbe3439c259c0f30bf41b4f98d9a930d339b" alt=""
data:image/s3,"s3://crabby-images/53c17/53c174dfcb72143fcb65cdc1bf946f28703efaf6" alt=""
data:image/s3,"s3://crabby-images/695ac/695ac189a1f9a8d8325e09378fc5ee1620bf92ef" alt=""
data:image/s3,"s3://crabby-images/c8966/c89667c08ca2a984cd2daec8aeb01575b12917a1" alt=""
0 comments:
Post a Comment