Because the entire inner loop is performed for each iteration of the outer loop, optimizations of the inner loop will have much greater effect than optimizations of the outer loop.
In many languages there are at least two types of loops – for loops and while loops – and they can be nested within each other.1 Tosin P. Adewumi has shown that performance of a while loop with an inner for loop is better than of a while loop without the inner for loop.2
It was observed that more computations are performed per unit time when an inner for loop is involved than otherwise. This implies, given the same number of computations to perform, the one with an inner for loop will finish faster than the one without it. This technique of loop optimization was observed across several programming languages and compilers or interpreters. In some cases, a while loop with an inner while loop performed slower than a while loop without an inner loop.
The two examples below, written in Python, present a while loop with an inner for loop and a while loop without an inner loop. Although both have the same terminating condition for their while loops, the first example will finish faster because of the inner for loop. The variable innermax is a fraction of the maxticketno variable in the first example.3
4. Python Nested For Loop From Techgeekbuz
Ghezzi, C; Jazayeri, M (1996). Programming Language Concepts (3rd edn.). John Wiley & Sons. ↩
Adewumi, Tosin (August 2018). "Inner loop program construct: a faster way for program execution". Open Computer Science. 8: 115–122. doi:10.1515/comp-2018-0004. https://doi.org/10.1515%2Fcomp-2018-0004 ↩
Vishal (2021-06-09). "Nested Loops in Python". PYnative. Retrieved 2022-09-07. https://pynative.com/python-nested-loops/ ↩