Time Complexity Intro

Time complexity and Big O notation

Time complexity is a concept used to describe the efficiency of an algorithm based on the time it takes to complete, relative to the size of the input. This helps us compare different algorithms to see which one is more efficient, especially as input sizes grow.

One of the most common ways to express time complexity is with Big O Notation.

What is Big O Notation?

Big O notation is a mathematical way to describe how an algorithm’s runtime grows as the input size increases. It provides an upper bound on the time (or number of steps) required for an algorithm to complete, so we can understand its worst-case scenario.

In Big O notation, we describe the runtime by focusing on the most significant term, ignoring constants and lower-order terms. For example, O(n + 10) simplifies to O(n) because, as n grows, the constant term (10) becomes less significant.

Why Use Big O Notation?

Big O notation allows us to:

  1. Predict Performance: Understand how an algorithm performs as the input size grows.
  2. Compare Algorithms: Quickly compare different algorithms based on their efficiency.
  3. Identify Bottlenecks: Find potential performance issues before they arise.

Common Types of Time Complexity

Here are the most common time complexities you'll encounter:

ComplexityNameExample Use Case
O(1)Constant TimeAccessing an array element
O(log n)LogarithmicBinary search
O(n)Linear TimeSimple loop through an array
O(n log n)LinearithmicEfficient sorting (e.g., merge sort)
O(n²)QuadraticNested loops
O(2ⁿ)ExponentialRecursive Fibonacci sequence
O(n!)FactorialGenerating all permutations

Graphical Representation

The following image shows the growth of different time complexities as the input size increases:

Big O Notation
https://www.linkedin.com/in/micasan