ここで説明するクイックセレクトを実装する小さなPythonコードがあります。
import random
def Quickselect(A, k):
if not A:
return
pivot = random.choice(A)
i = 0
A1 = []
A2 = [] # Two new arrays A1, A2 to store the split lists
for i in range(len(A)):
if A[i] < pivot :
A1.append(A[i])
else:
A2.append(A[i])
if k < len(A1):
return Quickselect(A1, k)
if k > len(A) - len(A2):
return Quickselect(A2, k-(len(A) - len(A2)))
else:
return pivot
pass
def main():
A = [45,1,27,56,12,56,88]
print(Quickselect(A,2))
pass
randrangeエラーが発生しているようです。何かがおかしいですか?
編集:random.choice
の代わりに実装されrandom.randint
ます。上記のコードは正常に機能しているようです。UserBlenderに感謝します。