Big O Notation

Home > Computer Science > Algorithms and data structures > Big O Notation

A notation used to describe the complexity of an algorithm in terms of the size of its input. Understanding Big O notation is crucial for analyzing and evaluating the efficiency of algorithms.

Time and Space Complexity: Understanding the concepts of run-time and memory requirements for algorithms and data structures.
Asymptotic Notations: Understanding Big O, Big Omega, and Big Theta notations to describe the upper, lower, and tight bounds of an algorithm's runtime.
Worst-case, Best-case, and Average-case analysis: Knowing how to analyze algorithms based on the best, worst, and average scenarios.
Recursion: Learning how to analyze recursive functions and solving recurrence relations.
Arrays: Understanding array operations and their time and space complexities.
Linked Lists: Basics of LinkedLists and how their operations differ from arrays.
Stacks and Queues: Understanding the push, pop, enqueue, and dequeue operations and their time complexities.
Trees: Learning about different types of trees such as binary trees, binary search trees, AVL trees, and red-black trees.
Graphs: Learning about different graph algorithms like BFS, DFS, Dijkstra's algorithm, Bellman-Ford algorithm, and Floyd Warshall algorithm.
Sorting and Searching algorithms: Understanding the different types of sorting and searching algorithms like Binary search, QuickSort, MergeSort, HeapSort, BubbleSort, InsertionSort, and SelectionSort.
O(1): This represents constant time complexity, which means that the algorithm or data structure takes the same amount of time to execute regardless of the input size.
O(log n): This represents logarithmic time complexity, which means that the execution time increases at a slower rate as the input size increases. Examples include binary search and some tree operations.
O(n): This represents linear time complexity, which means that the execution time increases linearly as the input size increases. Examples include linear search and some sorting algorithms like bubble sort and insertion sort.
O(n log n): This represents n times logarithmic time complexity, which means that the execution time increases at a faster rate than O(n) but still slower than O(n^2). Some common algorithms with this complexity include merge sort and quicksort.
O(n^2): This represents quadratic time complexity, which means that the execution time increases exponentially as the input size increases. Examples include some sorting algorithms like selection sort and bubble sort.
O(n^3): This represents cubic time complexity, which means that the execution time increases cubically as the input size increases.
O(2^n): This represents exponential time complexity, which means that the execution time doubles with every increase in input size. Examples include brute force algorithms that test every possible combination of inputs.
O(n!): This represents factorial time complexity and is the slowest of all. It means that the execution time increases by a factor of n! (n factorial) as the input size increases. Examples include brute force algorithms that test every permutation of inputs.
"Big O notation is used to classify algorithms according to how their run time or space requirements grow as the input size grows."
"Big O is a member of a family of notations invented by German mathematicians Paul Bachmann, Edmund Landau, and others, collectively called Bachmann–Landau notation or asymptotic notation."
"The letter O was chosen by Bachmann to stand for Ordnung, meaning the order of approximation."
"In analytic number theory, big O notation is often used to express a bound on the difference between an arithmetical function and a better understood approximation."
"Big O notation characterizes functions according to their growth rates: different functions with the same asymptotic growth rate may be represented using the same O notation."
"Yes, a description of a function in terms of big O notation usually only provides an upper bound on the growth rate of the function."
"Associated with big O notation are several related notations, using the symbols o, Ω, ω, and Θ, to describe other kinds of bounds on asymptotic growth rates."
"Big O notation is used in many other fields to provide similar estimates."
"Big O notation is a mathematical notation that describes the limiting behavior of a function when the argument tends towards a particular value or infinity."
"Big O is a member of a family of notations invented by German mathematicians Paul Bachmann, Edmund Landau, and others, collectively called Bachmann–Landau notation or asymptotic notation."
"The main factor used is how their run time or space requirements grow as the input size grows."
"Big O notation is often used to express a bound on the difference between an arithmetical function and a better understood approximation."
"Different functions with the same asymptotic growth rate may be represented using the same O notation."
"No, a description of a function in terms of big O notation usually only provides an upper bound on the growth rate of the function."
"The letter O was chosen by Bachmann to stand for Ordnung, meaning the order of approximation."
"Associated with big O notation are several related notations, using the symbols o, Ω, ω, and Θ, to describe other kinds of bounds on asymptotic growth rates."
"Big O notation is often used to classify the difference between an arithmetical function and a better understood approximation."
"Big O notation is used in many other fields to provide similar estimates."
"Different functions with the same asymptotic growth rate may be represented using the same O notation."
"No, a description of a function in terms of big O notation usually only provides an upper bound on the growth rate of the function."