<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;"># Written by Eric Martin for COMP9021


# Assumes that len(L) is a power of 2
def batcher_sort(L):
    half_size, size = 1, 2
    while half_size &lt; len(L):
        for group in range(0, len(L) // size):
            top = group * size
            for i in range(half_size):
                if L[top + i] &gt; L[top + i + half_size]:
                    L[top + i], L[top + i + half_size] = L[top + i + half_size], L[top + i]       
        span, double_span = half_size // 2, half_size
        while span:
            skip = half_size // span
            for group in range(len(L) // double_span):
                if (group + 1) % skip == 0:
                    continue
                top = span + group * double_span;
                for i in range(span):
                    if L[top + i] &gt; L[top + i + span]:
                        L[top + i], L[top + i + span] = L[top + i + span], L[top + i]
            span //= 2
            double_span //= 2
        half_size *= 2
        size *= 2
</pre></body></html>