私は、次のしているコードPythonコードの理解
def compare_and_swap(x, a, b):
if x[a] > x[b]:
x[a], x[b] = x[b], x[a]
def oddeven_merge(x, lo, hi, r):
step = r * 2
if step < hi - lo:
oddeven_merge(x, lo, hi, step)
oddeven_merge(x, lo + r, hi, step)
for i in range(lo + r, hi - r, step):
compare_and_swap(x, i, i + r)
else:
compare_and_swap(x, lo, lo + r)
def oddeven_merge_sort_range(x, lo, hi):
""" sort the part of x with indices between lo and hi.
Note: endpoints (lo and hi) are included.
"""
if (hi - lo) >= 1:
# if there is more than one element, split the input
# down the middle and first sort the first and second
# half, followed by merging them.
mid = lo + ((hi - lo)/2)
oddeven_merge_sort_range(x, lo, mid)
oddeven_merge_sort_range(x, mid + 1, hi)
oddeven_merge(x, lo, hi, 1)
def oddeven_merge_sort(x):
oddeven_merge_sort_range(x, 0, len(x)-1)
>>> data = [4, 3, 5, 6, 1, 7, 8]
>>> oddeven_merge_sort(data)
>>> data
[1, 2, 3, 4, 5, 6, 7, 8]
すべてが私にとっては明らかであるが、これだけの行は理解できない、私はそれが擬似コードを使用していますか?またはで読むことができますどのようにうまく
for i in range(lo + r, hi - r, step):
他の言語、例えばC++?
あなたが持っているものは非常に危険です、永遠にループする可能性があります。私はpythonの範囲と同等だとは思わない。 – Mat
@Mat:True。それは永遠に繰り返すかもしれませんが、私はC言語のようにプラスとマイナス両方のために働く方法を考えることはできません。私は肯定的なケースのためだけに働くように私の答えを更新しています。 – MAK
+1悪いステップについての良い点。 –