Lecture

What is Algorithm Complexity?

Algorithm complexity is a measure of how efficient an algorithm is, typically expressed using Big O notation.

Big O notation describes how the execution time or memory usage of an algorithm grows as the input size increases and is presented in the following forms:

NotationNameDescription
O(1)Constant Time ComplexityTakes constant time regardless of the input size
O(log n)Logarithmic Time ComplexityTime grows proportionally to the logarithm of the input size
O(n)Linear Time ComplexityTime grows proportionally to the input size
O(n log n)Linearithmic Time ComplexityTime grows proportionally to n log n of the input size
O(nΒ²)Quadratic Time ComplexityTime grows proportionally to the square of the input size
O(2ⁿ)Exponential Time ComplexityTime grows proportionally to the exponential of the input size

Here, the meanings of O and n are as follows:

  • 'O' (Big O): Denotes the order of an algorithm and measures time and space complexity. O stands for Order of, representing the upper bound of the algorithm's computational or memory demands as the input size grows.

  • 'n': Typically represents the input size of the algorithm.


For example, the meanings of each complexity are as follows:

  • O(1) indicates the algorithm's execution time is constant, regardless of the input size.

  • O(n) indicates the algorithm's execution time grows linearly with the input size.

  • O(nΒ²) indicates the execution time grows quadratically with the input size.


Evaluating Algorithm Complexity

Algorithm complexity is evaluated from two perspectives: time complexity and space complexity.


Time Complexity

Time complexity represents the time required by an algorithm to solve a problem.

It is usually measured by the number of computational steps needed depending on the input size.

For example, a simple loop runs proportionally to the input size, having linear time complexity, or O(n).

In contrast, a nested loop, where another loop occurs inside a for-loop, requires computations proportional to the square of the input size, resulting in quadratic time complexity, or O(nΒ²).


Space Complexity

Space complexity represents the amount of memory space required to execute an algorithm.

The amount of memory space includes the size of variables, data structures, and recursive call stacks used by the algorithm.

For example, using only a fixed number of variables results in constant space complexity, or O(1).

In contrast, if memory proportional to the input size is needed, it results in linear space complexity, or O(n).

Mission
0 / 1

Which of the following represents linear time complexity in Big O notation?

O(1)

O(log n)

O(n)

O(nΒ²)

Lecture

AI Tutor

Publish

Design

Upload

Notes

Favorites

Help

Code Editor

Run
Generate

Execution Result