SlideShare a Scribd company logo
Unit 2
Algorithm
Things To Be Discussed In This Unit
• Program Design
• Concept and Definition
• Design of algorithm
• Characteristic of algorithm
• Big O notation
2
Learning Objectives
• Understand the type of problem that will be covered in this class
• Recognize some problems for which sophisticated algorithms might not be
necessary.
• Question if your solution technique is an efficient one? Any room for
optimization?
3
Program Design
• Involves taking the specification and designing solutions, the designer needs to
adopt a design strategy.
• Solution Strategy should work correctly in all conditions
• A large program should be divided into small modules and sub modules.
• Other important criteria by which a program can be judged are execution time and
storage requirement
4
Algorithms
• The term ’algorithm’ refers to the sequence of instructions that must be followed
to solve a problem.
• Logical representation of the instructions which should be executed to perform a
meaningful task.
• Algorithms are generally created independent of underlying languages, i.e. an
algorithm can be implemented in more than one programming language.
5
An algorithm has certain characteristics
• Each instruction should be unique and concise.
• Each instruction should be relative in nature and should not be repeated infinitely
• Repetition of same task(s) should be avoided.
• The result should be available to the user after algorithm terminates.
6
NOTE:
• After an algorithm has been designed, its efficiency must be analyzed. i.e CPU time
and memory
• Memory space and running time should be taken care of.
• The importance of efficiency of an algorithm is in the correctness, i.e does it
always produce the correct result, and program complexity which considers
both the difficulty of implementing an algorithm along with its efficiency
7
Properties of an Algorithm
• Input: A number of quantities are provided to an algorithm initially before the algorithm
begins. These quantities are inputs which are processed by the algorithm.
• Definiteness: Each step must be clear and unambiguous.
• Effectiveness: Each step must be carried out in finite time.
• Finiteness: Algorithms must terminate after finite time or step
• Output: An algorithm must have output.
• Correctness: Correct set of output values must be produced from the each set of inputs.
8
Write an algorithm to find the greatest number among three numbers
Step 1: Read three numbers and store them in X, Y and Z
Step 2: Compare X and Y. if X is greater than Y then go to step 5 else go to step 3
Step 3: Compare Y and Z. if Y is greater than Z then print “Y is greatest” and go to step 7
otherwise go to step 4
Step 4: Print “Z is greatest” and go to step 7
Step 5: Compare X and Z. if X is greater than Z then print “X is greatest” and go to step 7
otherwise go to step 6
Step 6: Print “Z is greatest” and go to step 7
Step 7: Stop
9
Different Approaches To Designing An Algorithm
• A complex system may be divided into smaller units called modules.
• The advantage of modularity is that it focuses on specific module.
• Modularity enhances design clarity, which in turn eases implementation,
debugging, testing, documenting and maintenance of the project.
• To design a hierarchy of a system there are two possible approaches
• Top-down approach
• Bottom-up approach
10
Top-Down Approach
• How it is done?
• Identify the major components of the system,
• decompose them into their lower-level components and
• Iterate until the desired level of module complexity is achieved.
• It basically starts with the big picture. It breaks down from there into smaller
segments.
• Top-down design method takes the form of stepwise refinement.
11
Bottom-Up Approach
• A bottom-up approach is the piecing together of systems to give rise to more
complex systems
• Bottom-up method works with layers of abstraction.
• Elements are then linked together to form larger subsystems, which then in turn
are linked, sometimes in many levels, until a complete top-level system is formed.
• This strategy often resembles a "seed" model, by which the beginnings are small
but eventually grow in complexity and completeness.
12
Top-Down versus Bottom-Up Approach
• The top-down approach, however, is often useful way to better document a
design.
• The design activity should not be constrained to proceed according to a fixed
pattern but should be a blend of top-down and bottom-up approaches
13
Complexity
• When we talk of complexity in context of computers, we call it computational
complexity.
• Computational complexity is a characterization of the time or space requirements
for solving a problem by a particular algorithm.
• Lesser the complexity better an algorithm.
14
Complexity
• Given a particular problem, let ’n’ denote its size. The time required of a specific
algorithm for solving this problem is expressed by a function:
f : R->R
• Such that, f(n) is the largest amount of time needed by the algorithm to solve the
problem of size n.
• Function ‘f’ is usually called the time complexity function.
• Thus we conclude that the analysis of the program requires two main
considerations:
• Time Complexity (time required for completion)
• Space Complexity (memory required for completion)
15
Time Complexity
• While measuring the time complexity of an algorithm, we concentrate on
developing only the frequency count for all key statements
(statements that are important and are the basic instructions of an algorithm)
• This is because, it is often difficult to get reliable timing figure because of clock
limitations and the multiprogramming or the sharing environment.
16
Algorithm A
• In an algorithm A we may find that the statement a=a+1 is
independent and is not contained within any loop.
• Therefore, the number of times this shall be executed is 1.
• We say that the frequency count of an algorithm A is 1.
17
Algorithm B
• In this algorithm, i.e. B, the key statement is the assignment operation a=a+1.
• Because this statement is contained within a loop, the number of times it is
executed is n, as the loop runs for n times.
• The frequency count for this algorithm is n.
18
Algorithm C
• The frequency count for the statement a=a+1 is n2 as the inner loop runs n times,
each time the outer loop runs, the inner loop also runs for n times.
• If an algorithm perform f(n) basic operations when the size of its input is n, then its
total running time will be cf(n), where c is a constant that depends upon the
algorithm, on the way it is programmed, and on the way the
computer is used, but c does not depend on the size of the input
19
Space Complexity
• Space complexity is essentially the number of memory cells which an algorithm needs.
• A good algorithm keeps this number as small as possible, too.
• There is often a time-space-tradeoff involved in a problem, that is, it cannot be solved with few
computing time and low memory consumption.
• Space complexity is measured with respect to the input size for a given instance of a problem.
20
Naïve Algorithm Vs Efficient Algorithm
21
Ex 1: Greatest Common Divisor
• DEFINITION:
• For integers, a and b, their greatest common divisor or gcd(a,b) is the largest integer d so that
d divides both a and b
• Compute GCD
• Input: Integers a,b ≥0
• Output: gcd(a,b)
• Ex: Run on large numbers like
gcd(3198848,1653264)
22
Function NaiveGCD(a,b)
• PROBLEMS:
• Takes too much time to complete
• Not an optimal solution
23
Best=0
For d from 1 to a+b:
if d/a and d/b:
best=d
return best
Function efficientGCD(a,b)
• Lemma
• Let a’ be the remainder when a is divided by b, then
gcd(a,b)=gcd(a’,b)=gcd(b,a’)
• So what is gcd(357,234)?
24
If b=0:
return a
a’ = the remainder when a is divided by b
return efficientGCD(b,a’)
Example
Summary of naïve vs efficient algorithms
• Naïve algorithm is too slow
• The correct algorithm is much better
• Finding the correct algorithm requires knowing something interesting about the
problem
25
Big O notation
• To be continued on next slide…
26

More Related Content

What's hot (20)

Unit 3
Unit 3
rohassanie
 
Elements of programming
Elements of programming
baabtra.com - No. 1 supplier of quality freshers
 
C programming Ms. Pranoti Doke
C programming Ms. Pranoti Doke
Pranoti Doke
 
Unit 2
Unit 2
rohassanie
 
iFL: An Interactive Environment for Understanding Feature Implementations
iFL: An Interactive Environment for Understanding Feature Implementations
Institute of Science Tokyo
 
Python - Functions - Azure Jupyter Notebooks
Python - Functions - Azure Jupyter Notebooks
Adri Jovin
 
Chapter 02 functions -class xii
Chapter 02 functions -class xii
Praveen M Jigajinni
 
Sem1 plt xp_03
Sem1 plt xp_03
Niit Care
 
C101 – Intro to Programming with C
C101 – Intro to Programming with C
gpsoft_sk
 
Designing Architecture-aware Library using Boost.Proto
Designing Architecture-aware Library using Boost.Proto
Joel Falcou
 
Boost.Dispatch
Boost.Dispatch
Joel Falcou
 
Krml203
Krml203
Pedro Gonçalves
 
C Programming - Refresher - Part IV
C Programming - Refresher - Part IV
Emertxe Information Technologies Pvt Ltd
 
Visualizing Stakeholder Concerns with Anchored Map
Visualizing Stakeholder Concerns with Anchored Map
Takanori Ugai
 
HDR Defence - Software Abstractions for Parallel Architectures
HDR Defence - Software Abstractions for Parallel Architectures
Joel Falcou
 
(Costless) Software Abstractions for Parallel Architectures
(Costless) Software Abstractions for Parallel Architectures
Joel Falcou
 
Session 8 assertion_based_verification_and_interfaces
Session 8 assertion_based_verification_and_interfaces
Nirav Desai
 
Functions
Functions
Learn By Watch
 
Bad Code Smells
Bad Code Smells
kim.mens
 
Guiding Identification of Missing Scenarios for Dynamic Feature Location
Guiding Identification of Missing Scenarios for Dynamic Feature Location
Institute of Science Tokyo
 
C programming Ms. Pranoti Doke
C programming Ms. Pranoti Doke
Pranoti Doke
 
iFL: An Interactive Environment for Understanding Feature Implementations
iFL: An Interactive Environment for Understanding Feature Implementations
Institute of Science Tokyo
 
Python - Functions - Azure Jupyter Notebooks
Python - Functions - Azure Jupyter Notebooks
Adri Jovin
 
Sem1 plt xp_03
Sem1 plt xp_03
Niit Care
 
C101 – Intro to Programming with C
C101 – Intro to Programming with C
gpsoft_sk
 
Designing Architecture-aware Library using Boost.Proto
Designing Architecture-aware Library using Boost.Proto
Joel Falcou
 
Visualizing Stakeholder Concerns with Anchored Map
Visualizing Stakeholder Concerns with Anchored Map
Takanori Ugai
 
HDR Defence - Software Abstractions for Parallel Architectures
HDR Defence - Software Abstractions for Parallel Architectures
Joel Falcou
 
(Costless) Software Abstractions for Parallel Architectures
(Costless) Software Abstractions for Parallel Architectures
Joel Falcou
 
Session 8 assertion_based_verification_and_interfaces
Session 8 assertion_based_verification_and_interfaces
Nirav Desai
 
Bad Code Smells
Bad Code Smells
kim.mens
 
Guiding Identification of Missing Scenarios for Dynamic Feature Location
Guiding Identification of Missing Scenarios for Dynamic Feature Location
Institute of Science Tokyo
 

Similar to Algorithm and C code related to data structure (20)

01 CS316_Introduction.pdf5959695559655565
01 CS316_Introduction.pdf5959695559655565
yahiaf3k
 
Lecture 2 role of algorithms in computing
Lecture 2 role of algorithms in computing
jayavignesh86
 
Algorithm Introduction
Algorithm Introduction
Ashim Lamichhane
 
Unit 1, ADA.pptx
Unit 1, ADA.pptx
jinkhatima
 
Algorithm Analysis.pdf
Algorithm Analysis.pdf
NayanChandak1
 
Introduction to data structures and Algorithm
Introduction to data structures and Algorithm
Dhaval Kaneria
 
Cupdf.com introduction to-data-structures-and-algorithm
Cupdf.com introduction to-data-structures-and-algorithm
TarikuDabala1
 
Design & Analysis of Algorithm course .pptx
Design & Analysis of Algorithm course .pptx
JeevaMCSEKIOT
 
Introduction to data structures and Algorithm
Introduction to data structures and Algorithm
Dhaval Kaneria
 
Chapter1.1 Introduction.ppt
Chapter1.1 Introduction.ppt
Tekle12
 
Chapter1.1 Introduction to design and analysis of algorithm.ppt
Chapter1.1 Introduction to design and analysis of algorithm.ppt
Tekle12
 
Lecture01 algorithm analysis
Lecture01 algorithm analysis
Zara Nawaz
 
Modile-1-PPT-1-BCAC0207-AlgorithmDesign.pptx
Modile-1-PPT-1-BCAC0207-AlgorithmDesign.pptx
ryadavrohit26
 
Binary to hexadecimal algorithmic old.pptx
Binary to hexadecimal algorithmic old.pptx
bulbul931579
 
Algo_Lecture01.pptx
Algo_Lecture01.pptx
ShaistaRiaz4
 
Introduction to analysis algorithm in computer Science
Introduction to analysis algorithm in computer Science
tissandavid
 
introduction to analysis of algorithm in computer science
introduction to analysis of algorithm in computer science
tissandavid
 
2-Algorithms and Complexit data structurey.pdf
2-Algorithms and Complexit data structurey.pdf
ishan743441
 
DAA-Unit1.pptx
DAA-Unit1.pptx
NishaS88
 
Chp-1 DAA (2).pptx design analysis and algoritham presentation
Chp-1 DAA (2).pptx design analysis and algoritham presentation
vaishnavbhavna17
 
01 CS316_Introduction.pdf5959695559655565
01 CS316_Introduction.pdf5959695559655565
yahiaf3k
 
Lecture 2 role of algorithms in computing
Lecture 2 role of algorithms in computing
jayavignesh86
 
Unit 1, ADA.pptx
Unit 1, ADA.pptx
jinkhatima
 
Algorithm Analysis.pdf
Algorithm Analysis.pdf
NayanChandak1
 
Introduction to data structures and Algorithm
Introduction to data structures and Algorithm
Dhaval Kaneria
 
Cupdf.com introduction to-data-structures-and-algorithm
Cupdf.com introduction to-data-structures-and-algorithm
TarikuDabala1
 
Design & Analysis of Algorithm course .pptx
Design & Analysis of Algorithm course .pptx
JeevaMCSEKIOT
 
Introduction to data structures and Algorithm
Introduction to data structures and Algorithm
Dhaval Kaneria
 
Chapter1.1 Introduction.ppt
Chapter1.1 Introduction.ppt
Tekle12
 
Chapter1.1 Introduction to design and analysis of algorithm.ppt
Chapter1.1 Introduction to design and analysis of algorithm.ppt
Tekle12
 
Lecture01 algorithm analysis
Lecture01 algorithm analysis
Zara Nawaz
 
Modile-1-PPT-1-BCAC0207-AlgorithmDesign.pptx
Modile-1-PPT-1-BCAC0207-AlgorithmDesign.pptx
ryadavrohit26
 
Binary to hexadecimal algorithmic old.pptx
Binary to hexadecimal algorithmic old.pptx
bulbul931579
 
Algo_Lecture01.pptx
Algo_Lecture01.pptx
ShaistaRiaz4
 
Introduction to analysis algorithm in computer Science
Introduction to analysis algorithm in computer Science
tissandavid
 
introduction to analysis of algorithm in computer science
introduction to analysis of algorithm in computer science
tissandavid
 
2-Algorithms and Complexit data structurey.pdf
2-Algorithms and Complexit data structurey.pdf
ishan743441
 
DAA-Unit1.pptx
DAA-Unit1.pptx
NishaS88
 
Chp-1 DAA (2).pptx design analysis and algoritham presentation
Chp-1 DAA (2).pptx design analysis and algoritham presentation
vaishnavbhavna17
 
Ad

More from Self-Employed (7)

Queue AS an ADT (Abstract Data Type)
Queue AS an ADT (Abstract Data Type)
Self-Employed
 
Infix prefix postfix
Infix prefix postfix
Self-Employed
 
Ds lec 5_chap4
Ds lec 5_chap4
Self-Employed
 
Discrete mathematics counting and logic relation
Discrete mathematics counting and logic relation
Self-Employed
 
Abstract data types (adt) intro to data structure part 2
Abstract data types (adt) intro to data structure part 2
Self-Employed
 
2.2 inverse of a matrix
2.2 inverse of a matrix
Self-Employed
 
8086 architecture
8086 architecture
Self-Employed
 
Queue AS an ADT (Abstract Data Type)
Queue AS an ADT (Abstract Data Type)
Self-Employed
 
Infix prefix postfix
Infix prefix postfix
Self-Employed
 
Discrete mathematics counting and logic relation
Discrete mathematics counting and logic relation
Self-Employed
 
Abstract data types (adt) intro to data structure part 2
Abstract data types (adt) intro to data structure part 2
Self-Employed
 
2.2 inverse of a matrix
2.2 inverse of a matrix
Self-Employed
 
Ad

Recently uploaded (20)

Overview of Off Boarding in Odoo 18 Employees
Overview of Off Boarding in Odoo 18 Employees
Celine George
 
Analysis of Quantitative Data Parametric and non-parametric tests.pptx
Analysis of Quantitative Data Parametric and non-parametric tests.pptx
Shrutidhara2
 
Sustainable Innovation with Immersive Learning
Sustainable Innovation with Immersive Learning
Leonel Morgado
 
Ray Dalio How Countries go Broke the Big Cycle
Ray Dalio How Countries go Broke the Big Cycle
Dadang Solihin
 
Energy Balances Of Oecd Countries 2011 Iea Statistics 1st Edition Oecd
Energy Balances Of Oecd Countries 2011 Iea Statistics 1st Edition Oecd
razelitouali
 
How to Manage Upselling of Subscriptions in Odoo 18
How to Manage Upselling of Subscriptions in Odoo 18
Celine George
 
Nice Dream.pdf /
Nice Dream.pdf /
ErinUsher3
 
Exploring Ocean Floor Features for Middle School
Exploring Ocean Floor Features for Middle School
Marie
 
PEST OF WHEAT SORGHUM BAJRA and MINOR MILLETS.pptx
PEST OF WHEAT SORGHUM BAJRA and MINOR MILLETS.pptx
Arshad Shaikh
 
THERAPEUTIC COMMUNICATION included definition, characteristics, nurse patient...
THERAPEUTIC COMMUNICATION included definition, characteristics, nurse patient...
parmarjuli1412
 
Allomorps and word formation.pptx - Google Slides.pdf
Allomorps and word formation.pptx - Google Slides.pdf
Abha Pandey
 
How to Create an Event in Odoo 18 - Odoo 18 Slides
How to Create an Event in Odoo 18 - Odoo 18 Slides
Celine George
 
What are the benefits that dance brings?
What are the benefits that dance brings?
memi27
 
IDF 30min presentation - December 2, 2024.pptx
IDF 30min presentation - December 2, 2024.pptx
ArneeAgligar
 
Unit 3 Poster Sketches with annotations.pptx
Unit 3 Poster Sketches with annotations.pptx
bobby205207
 
BINARY files CSV files JSON files with example.pptx
BINARY files CSV files JSON files with example.pptx
Ramakrishna Reddy Bijjam
 
LDMMIA Spring Ending Guest Grad Student News
LDMMIA Spring Ending Guest Grad Student News
LDM & Mia eStudios
 
BUSINESS QUIZ PRELIMS | QUIZ CLUB OF PSGCAS | 9 SEPTEMBER 2024
BUSINESS QUIZ PRELIMS | QUIZ CLUB OF PSGCAS | 9 SEPTEMBER 2024
Quiz Club of PSG College of Arts & Science
 
Introduction to Generative AI and Copilot.pdf
Introduction to Generative AI and Copilot.pdf
TechSoup
 
Capitol Doctoral Presentation -June 2025.pptx
Capitol Doctoral Presentation -June 2025.pptx
CapitolTechU
 
Overview of Off Boarding in Odoo 18 Employees
Overview of Off Boarding in Odoo 18 Employees
Celine George
 
Analysis of Quantitative Data Parametric and non-parametric tests.pptx
Analysis of Quantitative Data Parametric and non-parametric tests.pptx
Shrutidhara2
 
Sustainable Innovation with Immersive Learning
Sustainable Innovation with Immersive Learning
Leonel Morgado
 
Ray Dalio How Countries go Broke the Big Cycle
Ray Dalio How Countries go Broke the Big Cycle
Dadang Solihin
 
Energy Balances Of Oecd Countries 2011 Iea Statistics 1st Edition Oecd
Energy Balances Of Oecd Countries 2011 Iea Statistics 1st Edition Oecd
razelitouali
 
How to Manage Upselling of Subscriptions in Odoo 18
How to Manage Upselling of Subscriptions in Odoo 18
Celine George
 
Nice Dream.pdf /
Nice Dream.pdf /
ErinUsher3
 
Exploring Ocean Floor Features for Middle School
Exploring Ocean Floor Features for Middle School
Marie
 
PEST OF WHEAT SORGHUM BAJRA and MINOR MILLETS.pptx
PEST OF WHEAT SORGHUM BAJRA and MINOR MILLETS.pptx
Arshad Shaikh
 
THERAPEUTIC COMMUNICATION included definition, characteristics, nurse patient...
THERAPEUTIC COMMUNICATION included definition, characteristics, nurse patient...
parmarjuli1412
 
Allomorps and word formation.pptx - Google Slides.pdf
Allomorps and word formation.pptx - Google Slides.pdf
Abha Pandey
 
How to Create an Event in Odoo 18 - Odoo 18 Slides
How to Create an Event in Odoo 18 - Odoo 18 Slides
Celine George
 
What are the benefits that dance brings?
What are the benefits that dance brings?
memi27
 
IDF 30min presentation - December 2, 2024.pptx
IDF 30min presentation - December 2, 2024.pptx
ArneeAgligar
 
Unit 3 Poster Sketches with annotations.pptx
Unit 3 Poster Sketches with annotations.pptx
bobby205207
 
BINARY files CSV files JSON files with example.pptx
BINARY files CSV files JSON files with example.pptx
Ramakrishna Reddy Bijjam
 
LDMMIA Spring Ending Guest Grad Student News
LDMMIA Spring Ending Guest Grad Student News
LDM & Mia eStudios
 
Introduction to Generative AI and Copilot.pdf
Introduction to Generative AI and Copilot.pdf
TechSoup
 
Capitol Doctoral Presentation -June 2025.pptx
Capitol Doctoral Presentation -June 2025.pptx
CapitolTechU
 

Algorithm and C code related to data structure

  • 2. Things To Be Discussed In This Unit • Program Design • Concept and Definition • Design of algorithm • Characteristic of algorithm • Big O notation 2
  • 3. Learning Objectives • Understand the type of problem that will be covered in this class • Recognize some problems for which sophisticated algorithms might not be necessary. • Question if your solution technique is an efficient one? Any room for optimization? 3
  • 4. Program Design • Involves taking the specification and designing solutions, the designer needs to adopt a design strategy. • Solution Strategy should work correctly in all conditions • A large program should be divided into small modules and sub modules. • Other important criteria by which a program can be judged are execution time and storage requirement 4
  • 5. Algorithms • The term ’algorithm’ refers to the sequence of instructions that must be followed to solve a problem. • Logical representation of the instructions which should be executed to perform a meaningful task. • Algorithms are generally created independent of underlying languages, i.e. an algorithm can be implemented in more than one programming language. 5
  • 6. An algorithm has certain characteristics • Each instruction should be unique and concise. • Each instruction should be relative in nature and should not be repeated infinitely • Repetition of same task(s) should be avoided. • The result should be available to the user after algorithm terminates. 6
  • 7. NOTE: • After an algorithm has been designed, its efficiency must be analyzed. i.e CPU time and memory • Memory space and running time should be taken care of. • The importance of efficiency of an algorithm is in the correctness, i.e does it always produce the correct result, and program complexity which considers both the difficulty of implementing an algorithm along with its efficiency 7
  • 8. Properties of an Algorithm • Input: A number of quantities are provided to an algorithm initially before the algorithm begins. These quantities are inputs which are processed by the algorithm. • Definiteness: Each step must be clear and unambiguous. • Effectiveness: Each step must be carried out in finite time. • Finiteness: Algorithms must terminate after finite time or step • Output: An algorithm must have output. • Correctness: Correct set of output values must be produced from the each set of inputs. 8
  • 9. Write an algorithm to find the greatest number among three numbers Step 1: Read three numbers and store them in X, Y and Z Step 2: Compare X and Y. if X is greater than Y then go to step 5 else go to step 3 Step 3: Compare Y and Z. if Y is greater than Z then print “Y is greatest” and go to step 7 otherwise go to step 4 Step 4: Print “Z is greatest” and go to step 7 Step 5: Compare X and Z. if X is greater than Z then print “X is greatest” and go to step 7 otherwise go to step 6 Step 6: Print “Z is greatest” and go to step 7 Step 7: Stop 9
  • 10. Different Approaches To Designing An Algorithm • A complex system may be divided into smaller units called modules. • The advantage of modularity is that it focuses on specific module. • Modularity enhances design clarity, which in turn eases implementation, debugging, testing, documenting and maintenance of the project. • To design a hierarchy of a system there are two possible approaches • Top-down approach • Bottom-up approach 10
  • 11. Top-Down Approach • How it is done? • Identify the major components of the system, • decompose them into their lower-level components and • Iterate until the desired level of module complexity is achieved. • It basically starts with the big picture. It breaks down from there into smaller segments. • Top-down design method takes the form of stepwise refinement. 11
  • 12. Bottom-Up Approach • A bottom-up approach is the piecing together of systems to give rise to more complex systems • Bottom-up method works with layers of abstraction. • Elements are then linked together to form larger subsystems, which then in turn are linked, sometimes in many levels, until a complete top-level system is formed. • This strategy often resembles a "seed" model, by which the beginnings are small but eventually grow in complexity and completeness. 12
  • 13. Top-Down versus Bottom-Up Approach • The top-down approach, however, is often useful way to better document a design. • The design activity should not be constrained to proceed according to a fixed pattern but should be a blend of top-down and bottom-up approaches 13
  • 14. Complexity • When we talk of complexity in context of computers, we call it computational complexity. • Computational complexity is a characterization of the time or space requirements for solving a problem by a particular algorithm. • Lesser the complexity better an algorithm. 14
  • 15. Complexity • Given a particular problem, let ’n’ denote its size. The time required of a specific algorithm for solving this problem is expressed by a function: f : R->R • Such that, f(n) is the largest amount of time needed by the algorithm to solve the problem of size n. • Function ‘f’ is usually called the time complexity function. • Thus we conclude that the analysis of the program requires two main considerations: • Time Complexity (time required for completion) • Space Complexity (memory required for completion) 15
  • 16. Time Complexity • While measuring the time complexity of an algorithm, we concentrate on developing only the frequency count for all key statements (statements that are important and are the basic instructions of an algorithm) • This is because, it is often difficult to get reliable timing figure because of clock limitations and the multiprogramming or the sharing environment. 16
  • 17. Algorithm A • In an algorithm A we may find that the statement a=a+1 is independent and is not contained within any loop. • Therefore, the number of times this shall be executed is 1. • We say that the frequency count of an algorithm A is 1. 17
  • 18. Algorithm B • In this algorithm, i.e. B, the key statement is the assignment operation a=a+1. • Because this statement is contained within a loop, the number of times it is executed is n, as the loop runs for n times. • The frequency count for this algorithm is n. 18
  • 19. Algorithm C • The frequency count for the statement a=a+1 is n2 as the inner loop runs n times, each time the outer loop runs, the inner loop also runs for n times. • If an algorithm perform f(n) basic operations when the size of its input is n, then its total running time will be cf(n), where c is a constant that depends upon the algorithm, on the way it is programmed, and on the way the computer is used, but c does not depend on the size of the input 19
  • 20. Space Complexity • Space complexity is essentially the number of memory cells which an algorithm needs. • A good algorithm keeps this number as small as possible, too. • There is often a time-space-tradeoff involved in a problem, that is, it cannot be solved with few computing time and low memory consumption. • Space complexity is measured with respect to the input size for a given instance of a problem. 20
  • 21. Naïve Algorithm Vs Efficient Algorithm 21
  • 22. Ex 1: Greatest Common Divisor • DEFINITION: • For integers, a and b, their greatest common divisor or gcd(a,b) is the largest integer d so that d divides both a and b • Compute GCD • Input: Integers a,b ≥0 • Output: gcd(a,b) • Ex: Run on large numbers like gcd(3198848,1653264) 22
  • 23. Function NaiveGCD(a,b) • PROBLEMS: • Takes too much time to complete • Not an optimal solution 23 Best=0 For d from 1 to a+b: if d/a and d/b: best=d return best
  • 24. Function efficientGCD(a,b) • Lemma • Let a’ be the remainder when a is divided by b, then gcd(a,b)=gcd(a’,b)=gcd(b,a’) • So what is gcd(357,234)? 24 If b=0: return a a’ = the remainder when a is divided by b return efficientGCD(b,a’) Example
  • 25. Summary of naïve vs efficient algorithms • Naïve algorithm is too slow • The correct algorithm is much better • Finding the correct algorithm requires knowing something interesting about the problem 25
  • 26. Big O notation • To be continued on next slide… 26