CONCEPTS OF ALGORITHMS CS211
INTRODUCTION
Teacher: Ghaida Alhamidi
g.alhamidi@qu.edu.sa
Introduction to Data Structure and Algorithms
• Why we need to study Algorithm?
• Computer programs would not exist without algorithms.
• Computer applications becoming indispensable in almost all
aspects of our lives, so that studying algorithms becomes a
necessity for more and more important.
Introduction to Data Structure and Algorithms
• What is an Algorithm?
• Algorithm: is a precise sequence of unambiguous
instructions for solving a problem.
That means obtaining a required output for specific input in
a finite amount of time.
Introduction to Data Structure and Algorithms
• Algorithm is intermediate step between modelling and
simulation.
Introduction to Data Structure and Algorithms
• How we can write Algorithm?
Algorithm can be written using
1. Natural Language
2. Flow chart is a method of expressing an algorithm by
a collection of connected geometric shapes containing
descriptions of the algorithm’s steps.
3. Pseudo-code Language.
Introduction to Data Structure and Algorithms
• Important points about Algorithm
• The non-ambiguity requirement for each step of an
algorithm cannot be compromised.
• The range of inputs has to be specified carefully.
• The same algorithm can be represented in several different
ways.
• There may exist several algorithms for solving the same
problem.
• Algorithms for the same problem can be based on very
different ideas and can solve the problem with dramatically
different speeds.
Introduction to Data Structure and Algorithms
• Fundamental of Algorithmic problem solving.
1. Understanding the Problem :
• a correct algorithm is not one that works most of the time, but one
that works correctly for all legitimate inputs.
2. Checking the Capabilities of the Computational Device
• algorithm can be applied in different types of computing devices,
also in single or parallel processor.
3. Choosing between Exact and Approximate Problem Solving
• Solving the problem exactly, for example extracting square roots for
integer number.
• Solving the problem approximately, for example extracting square
roots for float number.
Introduction to Data Structure and Algorithms
• Fundamental of Algorithmic problem solving.
4. Algorithm Design Techniques
• It provide guidance for designing algorithms for new problems.
• Algorithm design techniques make it possible to classify
algorithms according to an underlying design idea.
5. Designing an Algorithm and Data Structures
• Data structures is an important for both design and analysis of
algorithms.
6. Methods of Specifying an Algorithm
• Pseudocode is usually more precise than natural language.
• Flowchart can be found only in old algorithm books.
Introduction to Data Structure and Algorithms
• Fundamental of Algorithmic problem solving.
7. Proving an Algorithm’s Correctness
• For some algorithms, a proof of correctness is quite easy; for
others, it can be quite complex.
• A common technique for proving correctness is to use
Mathematical Induction.
8. Analyzing an Algorithm
• Analyzing an Algorithm for efficiency:
time efficiency, indicating how fast the algorithm runs.
space efficiency, indicating how much extra memory it uses.
• Doing that either heuristically or experimentally.
Introduction to Data Structure and Algorithms
• Fundamental of Algorithmic problem solving.
9. Coding an Algorithm
• The validity of programs is still established by testing.
• Test and debug your program thoroughly whenever you
implement an algorithm.
** Even if you have been fortunate (lucky) enough to get an
algorithmic idea that seems perfect, you should still try to see
whether it can be improved.
Introduction to Data Structure and Algorithms
• Algorithm
Design and
Analysis
steps
Introduction to Data Structure and Algorithms
• Design Techniques and Strategies
• Brute force • Iterative improvement
• Greedy approach • Transform and conquer
• Divide and Conquer • Backtracking
• Dynamic programming • Space and time trade-offs
• Decrease and conquer • Branch and bound
Introduction to Data Structure and Algorithms
• Important problem types
1. Sorting
2. Searching
3. String processing
4. Graph problems
5. Combinatorial problems
6. Geometric problems
7. Numerical problems