Fact 2.1. When xi is swapped the rst time, the pivot
xj of the current partitioning step satises i j < i
or i < j i, or xi is itself the pivot element.
Figure 2 illustrates how the element x5 = 8 is moved
during the execution of randomized Quicksort. Circled
elements are the selected pivots. The rst two selected
pivots 14 and 4 do not cause 8 to be swapped, since
8 is already correctly located with respect to the nal
positions of of the pivots 14 and 4. The rst pivot
causing 8 to be swapped is x15 = 7, since 5 = 7,
15 = 6, and 5 15 < 5.
In the succeeding recursive calls after the rst swap
of an element xi, the positions of xi in the array are
unrelated to i and i. Eventually, xi is either picked as
a pivot or becomes a single element input to a recursive
call (the base case is reached), after which xi does not
move further.
In the following we let di = ji