I’m happy to move these to a new thread / topic – @paulstgeorge, go ahead and create one.
One example I like is the Python documentation of itertools.permutations.
- itertools — Functions creating iterators for efficient looping — Python 3.12.1 documentation
- cpython/Modules/itertoolsmodule.c at main · python/cpython · GitHub
It is very idiomatically Python – the use of a separate index lookup, of slicing, and of reversed()
– so it doesn’t translate well to Java, but it is pretty interesting as an approach.
def permutations(iterable, r=None):
# permutations('ABCD', 2) --> AB AC AD BA BC BD CA CB CD DA DB DC
# permutations(range(3)) --> 012 021 102 120 201 210
pool = tuple(iterable)
n = len(pool)
r = n if r is None else r
if r > n:
return
indices = list(range(n))
cycles = list(range(n, n-r, -1))
yield tuple(pool[i] for i in indices[:r])
while n:
for i in reversed(range(r)):
cycles[i] -= 1
if cycles[i] == 0:
indices[i:] = indices[i+1:] + indices[i:i+1]
cycles[i] = n - i
else:
j = cycles[i]
indices[i], indices[-j] = indices[-j], indices[i]
yield tuple(pool[i] for i in indices[:r])
break
else:
return