Download presentation
Presentation is loading. Please wait.
Published byBruce Parrish Modified over 8 years ago
1
FURQAN MAJEED ALGORITHMS
2
A computer algorithm is a detailed step-by-step method for solving a problem by using a computer. An algorithm is a sequence of unambiguous instructions for solving a problem in a finite amount of time. More generally, an Algorithm is any well defined computational procedure that takes collection of elements as input and produces a collection of elements as output. Algorithm Input output What is Algorithm?
3
Most basic and popular algorithms are Sorting algorithms Searching algorithms Which algorithm is best? Mainly, it depends upon various factors, for example in case of sorting The number of items to be sorted The extent to which the items are already sorted Possible restrictions on the item values The kind of storage device to be used etc. Popular Algorithms, Factors of Dependence
4
Problem The statement of the problem specifies, in general terms, the desired input/output relationship. Algorithm The algorithm describes a specific computational procedure for achieving input/output relationship. Example One might need to sort a sequence of numbers into non-decreasing order. Algorithms Various algorithms e.g. merge sort, quick sort, heap sorts, radix sort, counting sort etc. One Problem, Many Algorithms
5
Brute Force Straightforward, naïve/simple approach Mostly expensive Divide-and-Conquer Divide into smaller sub-problems Iterative Improvement Improve one change at a time Decrease-and-Conquer Decrease instance size Transform-and-Conquer Modify problem first and then solve it Space and Time Tradeoffs Use more space now to save time later Important Designing Techniques
6
Greedy Approach Locally optimal decisions, can not change once made. Efficient Easy to implement The solution is expected to be optimal Every problem may not have greedy solution Dynamic programming Decompose into sub-problems like divide and conquer Sub-problems are dependant Record results of smaller sub-problems Re-use it for further occurrence Mostly reduces complexity exponential to polynomial Some of the Important Designing Techniques
7
Problem Strategy Algorithm Input Output Steps Analysis Correctness Time & Space Optimality Implementation Verification Problem Solving Process
8
Design assumption Level of abstraction which meets our requirements Neither more nor less e.g. [0, 1] infinite continuous interval Analysis independent of the variations in Machine Operating system Programming languages Compiler etc. Low-level details will not be considered Our model will be an abstraction of a standard generic single-processor machine, called a random access machine or RAM. Model of Computation (Assumptions)
9
A RAM is assumed to be an idealized machine Infinitely large random-access memory Instructions execute sequentially Every instruction is in fact a basic operation on two values in the machines memory which takes unit time. These might be characters or integers. Example of basic operations include Assigning a value to a variable Arithmetic operation (+, -, ×, /) on integers Performing any comparison e.g. a < b Boolean operations Accessing an element of an array. Model of Computation (Assumptions)
10
In theoretical analysis, computational complexity Estimated in asymptotic sense, i.e. Estimating for large inputs Big O, Omega, Theta etc. notations are used to compute the complexity Asymptotic notations are used because different implementations of algorithm may differ in efficiency Efficiencies of two given algorithm are related By a constant multiplicative factor Called hidden constant. Model of Computation (Assumptions)
11
First poor assumption We assumed that each basic operation takes constant time, i.e. model allows Adding Multiplying Comparing etc. two numbers of any length in constant time Addition of two numbers takes a unit time! Not good because numbers may be arbitrarily Addition and multiplication both take unit time! Again very bad assumption Drawbacks in Model of Computation
12
Finally what about Our Model? But with all these weaknesses, our model is not so bad because we have to give the Comparison not the absolute analysis of any algorithm. We have to deal with large inputs not with the small size Model seems to work well describing computational power of modern nonparallel machines Can we do Exact Measure of Efficiency ? Exact, not asymptotic, measure of efficiency can be sometimes computed but it usually requires certain assumptions concerning implementation Model of Computation not so Bad
13
Analysis will be performed with respect to this computational model for comparison of algorithms We will give asymptotic analysis not detailed comparison i.e. for large inputs We will use generic uniprocessor random- access machine (RAM) in analysis All memory equally expensive to access No concurrent operations All reasonable instructions take unit time, except, of course, function calls Summary : Computational Model
14
DESIGN AND ANALYSIS In order to understand design and analysis procedure we will do an example
15
SELECTION PROBLEM Suppose you want to purchase a Laptop You want to pick fastest Laptop But fast Laptops are expensive You cannot decide which one is more important price or speed
16
SELECTION PROBLEM Definitely do not want a Laptop if there is a another Laptop that is both fast and cheaper We say that fast cheap Laptops “dominates” the slow expensive So given a list of Laptops we want those that are not dominated by the other
17
CRITERION FOR SELECTION Two criterion for selection: Speed Price
18
MATHEMATICAL MODEL P is in two dimensional space and its coordinates are P=(p.x, p.y) (x,y) x is speed of Laptop y is negation of price We can say about y High value of y mean cheap Laptop and low y means Laptop is expensive A point p is said to be dominated by a point q if p.x <= q.x and p.y <= q.y In an array of points (Laptops) P={p 1,p 2,p 3,….,p n } a maximal point is not dominated by any other point
19
EXAMPLE (700,15) (500,20) (200,1) (1000,50) (900,35) (800,30) (1400,70) (1500,80) (1200,60)
20
EXAMPLE Given a set of point P={p 1,p 2,p 3,….,p n } output the maximal points Those points of P such that p i is not dominated by any other point
21
BRUTE-FORCE ALGORITHM Maximal ( int n, Point p[1……n]) 1 for i = 1 to n 2 maximal = true 3 for j = 1 to n 4 if( i != j ) and (p[i].x <= p [j]. x) and (p [i].y <= p [j].y) 5 maximal = false; 6 break; 7if (maximal == true) 8then output p [i].x, p[i]. y
22
RUNNING TIME ANALYSIS We can observe that: The running time depends upon the input size. Different input of the same size may result different time
23
RUNNING TIME ANALYSIS Count the number of steps of the pseudo code that are executed Or count the number of times an element of p is accessed Or number of comparisons that are performed
24
ANALYSIS OF SELECTION PROBLEM Input size is n We will count how number of steps
25
BRUTE-FORCE ALGORITHM Maximal(int n, Point p[1……n]) 1 for i = 1 to n 2 maximal = true 3 for j = 1 to n 4 if( i != j ) and (p[i].x <= p [j]. x) and (p [i].y <= p [j].y) 5 maximal = false; 6 break; 7if (maximal == true) 8 output p [i].x, p[i]. y n times 1 time n times 5 times 2 times Worst Case Analysis
26
ANALYSIS OF SELECTION PROBLEM The outer loop runs n times For each iteration. The inner loop runs n times in the worst case P is accessed four times in the if statement The output statement accesses p 2 times
27
Maximal(int n, Point p[1……n]) 1 for i = 1 to n 2 maximal = true 3 for j = 1 to n 4 if( i != j ) and (p[i].x <= p [j]. x) and (p [i].y <= p [j].y) 5 maximal = false; 6 break; 7if (maximal == true) 8 output p [i].x, p[i]. y n times 1 time n times 5 times 2 times
28
ANALYSIS OF SELECTION PROBLEM In the worst case every point is maximal so every point is output Worst-case time is:
29
ANALYSIS OF SELECTION PROBLEM
30
Suppose n=50 and We use a computer whose speed is 10000000 instructions per second Then this computer requires
31
COMPLEXITY OF THE ALGORITHMS Algorithm complexity is the work done by the algorithm there are following complexities: a.Worst case time b.Average case time c.Best case time d.Expected time
32
GROWTH OF FUNCTIONS Input SizeTime of T(n) 500.01265 1000.0503 5001.2515 10005.003 5000125.015 10000500.03 10000050000.3 10000005000003
33
IMPORTANT We will almost always work with worst case time. Average case time is most difficult to compute Worst case refer to the upper limit on the running time
34
ANALYSIS OF SELECTION PROBLEM T(n) is Asymptotically equivalent to n 2
35
DIVIDE & CONQUER A strategy to solve large number of problems. It has following stages: Divide : divide the problem into small number of pieces Conquer : Solve each piece by applying divide and conquer recursively Combine : Rearrange the pieces Examples: MergeSort, QuickSort
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.