Podcast
Questions and Answers
What does benchmarking software measure?
What does benchmarking software measure?
A computer's power in flops (floating point operations per second).
What is the approximate power of today's consumer computers?
What is the approximate power of today's consumer computers?
A few Gigaflops (10^6 flops)
What is the approximate power of the best current supercomputers?
What is the approximate power of the best current supercomputers?
About 1000 Teraflops (10^15 flops)
Time complexity is the evaluation of the execution time of an algorithm.
Time complexity is the evaluation of the execution time of an algorithm.
Signup and view all the answers
Space complexity is the evaluation of the memory space occupied by the execution of an algorithm.
Space complexity is the evaluation of the memory space occupied by the execution of an algorithm.
Signup and view all the answers
To save computing time, you have to use less memory space
To save computing time, you have to use less memory space
Signup and view all the answers
What is the complexity parameter for the factorial function?
What is the complexity parameter for the factorial function?
Signup and view all the answers
What is the complexity parameter for multiplying all the elements of an array of integers by a given integer?
What is the complexity parameter for multiplying all the elements of an array of integers by a given integer?
Signup and view all the answers
What is the complexity parameter for summing the first elements of each row in a two-dimensional table?
What is the complexity parameter for summing the first elements of each row in a two-dimensional table?
Signup and view all the answers
What is the constant execution time for an integer assignment?
What is the constant execution time for an integer assignment?
Signup and view all the answers
What is the constant execution time for an integer comparison?
What is the constant execution time for an integer comparison?
Signup and view all the answers
What is the constant execution time for an elementary operation on integers?
What is the constant execution time for an elementary operation on integers?
Signup and view all the answers
The cost of declarations, assignments and return is taken into account when calculating complexity.
The cost of declarations, assignments and return is taken into account when calculating complexity.
Signup and view all the answers
Complexity at worst refers to the maximum execution time for an algorithm.
Complexity at worst refers to the maximum execution time for an algorithm.
Signup and view all the answers
Medium complexity refers to the average execution time for an algorithm.
Medium complexity refers to the average execution time for an algorithm.
Signup and view all the answers
What does the O
notation, also known as the Landau notation, verify?
What does the O
notation, also known as the Landau notation, verify?
Signup and view all the answers
What does the O
notation verify?
What does the O
notation verify?
Signup and view all the answers
X = O(x^2) for x>1, since x < x^2.
X = O(x^2) for x>1, since x < x^2.
Signup and view all the answers
X^2 = O(x^3) for x>1, since x^2 < x^3.
X^2 = O(x^3) for x>1, since x^2 < x^3.
Signup and view all the answers
100*x = O(x^2) for x>100, since x < x^2
100*x = O(x^2) for x>100, since x < x^2
Signup and view all the answers
In(x) = O(x) for x>0, In(x)<x.
In(x) = O(x) for x>0, In(x)<x.
Signup and view all the answers
For i>0, x = 0(exp(x)), since for any x, x/ln(x)> i, xi < exp(x).
For i>0, x = 0(exp(x)), since for any x, x/ln(x)> i, xi < exp(x).
Signup and view all the answers
Ω notation: f = Ω(g) if there are constants c>0 and no such that f(x) ≤ c*g(x) for all x ≥ no.
Ω notation: f = Ω(g) if there are constants c>0 and no such that f(x) ≤ c*g(x) for all x ≥ no.
Signup and view all the answers
F and g being functions, f = θ(g) if there are constants c1, c2, strictly positive and no such that c1g(x) ≤ f(x) ≤ c2g(x) for all x ≥ no
F and g being functions, f = θ(g) if there are constants c1, c2, strictly positive and no such that c1g(x) ≤ f(x) ≤ c2g(x) for all x ≥ no
Signup and view all the answers
What is O(1) complexity?
What is O(1) complexity?
Signup and view all the answers
What is O(log(n)) complexity?
What is O(log(n)) complexity?
Signup and view all the answers
Algorithms of polynomial complexity can be used for large data sets.
Algorithms of polynomial complexity can be used for large data sets.
Signup and view all the answers
Exponential algorithms are usable in practice.
Exponential algorithms are usable in practice.
Signup and view all the answers
Moore's law states that the speed of processors doubles every 18 months.
Moore's law states that the speed of processors doubles every 18 months.
Signup and view all the answers
The volume of data stored in information systems is increasing linearly.
The volume of data stored in information systems is increasing linearly.
Signup and view all the answers
What is the complexity of the sequential search algorithm in the best case?
What is the complexity of the sequential search algorithm in the best case?
Signup and view all the answers
What is the complexity of the sequential search algorithm on average?
What is the complexity of the sequential search algorithm on average?
Signup and view all the answers
What is the complexity of the dichotomous search algorithm in the worst case?
What is the complexity of the dichotomous search algorithm in the worst case?
Signup and view all the answers
What is the complexity of the dichotomous search algorithm on average?
What is the complexity of the dichotomous search algorithm on average?
Signup and view all the answers
What is the complexity of the iterative factorial algorithm?
What is the complexity of the iterative factorial algorithm?
Signup and view all the answers
What is complexity parameter for the recursive factorial algorithm?
What is complexity parameter for the recursive factorial algorithm?
Signup and view all the answers
What is the complexity of the recursive factorial algorithm?
What is the complexity of the recursive factorial algorithm?
Signup and view all the answers
Derecursiving an algorithm does not change the shape of its complexity.
Derecursiving an algorithm does not change the shape of its complexity.
Signup and view all the answers
Moving to terminal recursion changes the shape of the complexity.
Moving to terminal recursion changes the shape of the complexity.
Signup and view all the answers
What is the complexity of the bubble sort algorithm in the worst case?
What is the complexity of the bubble sort algorithm in the worst case?
Signup and view all the answers
Selection and insertion sorts are also quadratic.
Selection and insertion sorts are also quadratic.
Signup and view all the answers
There are quasi-linear sorting algorithms.
There are quasi-linear sorting algorithms.
Signup and view all the answers
The complexity of an algorithm is the number of operations required to execute the algorithm.
The complexity of an algorithm is the number of operations required to execute the algorithm.
Signup and view all the answers
The complexity of a comparative sorting algorithm is based on the number of comparisons made.
The complexity of a comparative sorting algorithm is based on the number of comparisons made.
Signup and view all the answers
The complexity of multiplying or adding long integers is based on the number of bit operations.
The complexity of multiplying or adding long integers is based on the number of bit operations.
Signup and view all the answers
The complexity of multiplying two polynomials is based on summing or multiplying real numbers.
The complexity of multiplying two polynomials is based on summing or multiplying real numbers.
Signup and view all the answers
The number of recursive calls in a recursive function is not indicative of the time complexity.
The number of recursive calls in a recursive function is not indicative of the time complexity.
Signup and view all the answers
The number of assignment operations is indicative of the time complexity in algorithms that move a lot of data.
The number of assignment operations is indicative of the time complexity in algorithms that move a lot of data.
Signup and view all the answers
It's easy to identify which operations are important when studying an algorithm.
It's easy to identify which operations are important when studying an algorithm.
Signup and view all the answers
Study Notes
Complexity Calculations
- Algorithms are evaluated for time complexity and how long they take to run
- Comparing algorithms with the same output helps determine the best choice
- Examples of this include determining how long to calculate a factor of 100 and which sorting algorithm is best in a scenario where an item in an array was just changed
Levels of Complexity Assessment
- Algorithmic level: Analyzing and calculating complexity
- Implementation level: Testing the program experimentally
Experimental Complexity
- Evaluating program execution time experimentally
- Execution time measurements are in nanoseconds
- Different algorithms' execution times are shown in a chart
- Factors like programming language, computer, and operating system influence experimental evaluation
Benchmarking
- Software for measuring computer power in floating-point operations per second (flops)
- Power varies depending on the tasks (calculations, integers, reals, displays)
- Modern computers measure in Gigaflops (10^6) and supercomputers in Teraflops (10^12) (www.top500.org)
Temporal vs. Spatial Complexity
- Example: Swapping two integer values efficiently using two variables and operations
- Time complexity: measuring execution time
- Spatial complexity: evaluating memory usage
Complexity Parameter
- Example: Calculating factorial of 'n' using a function
- Complexity parameter is 'n' value
- Example: Multiplying array elements by a constant value
Complexity Classes
- O(1): Constant time; execution time is not affected by input size
- O(log n): Logarithmic time; execution time grows slowly with input size
- O(n): Linear time; execution time grows proportionally to input size
- O(n log n): Quasi-linear time; execution time grows slightly faster than linear
- O(n2): Quadratic time; execution time increases significantly with input size
- O(ni): Polynomial time; execution time is influenced by parameters
- O(2n): Exponential time; execution time increases dramatically with input
Studying That Suits You
Use AI to generate personalized quizzes and flashcards to suit your learning preferences.
Related Documents
Description
This quiz focuses on understanding time complexity and the methods used to analyze and benchmark algorithms. Explore how different factors such as programming language and system configuration influence execution times, and learn how to evaluate algorithm performance experimentally.