Эффективная реализация сортировки слиянием в PythonPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Эффективная реализация сортировки слиянием в Python

Сообщение Anonymous »

Код: Выделить всё

def merge(arr, l, m, r):
merged_arr = []
i, j = 0, 0
while (i < len(arr[l:m])) and (j < len(arr[m:r+1])):
if arr[l+i] < arr[m+j]:
merged_arr.append(arr[l+i])
i += 1
elif arr[l+i] >= arr[m+j]:
merged_arr.append(arr[m+j])
j += 1
merged_arr.extend(arr[m+j:r+1])
merged_arr.extend(arr[l+i:m])
arr[l:r+1] = merged_arr
return

def merge_sort(arr, l, r):
if r > l:
m = (l + r) // 2
merge_sort(arr, l, m)
merge_sort(arr, m+1, r)
return merge(arr, l, m, r)

Я не уверен, что не так с моей функцией слияния. Хорошо работает следующее:

Код: Выделить всё

print(merge([1,4,7,8,9,20,  0,4,5,15,67,68], 0, 6,12))
Однако это не дает правильного результата:

Код: Выделить всё

print(merge_sort([1, 5, 4, 2, 33, 4, 2, 44, 22, 0], 0, 10))


Подробнее здесь: https://stackoverflow.com/questions/786 ... -in-python
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как рекурсивная сортировка подмассивов в алгоритме сортировки слиянием без реализации условий сортировки
    Anonymous » » в форуме JAVA
    0 Ответы
    145 Просмотры
    Последнее сообщение Anonymous
  • Вопрос о коде Python для сортировки слиянием
    Anonymous » » в форуме Python
    0 Ответы
    15 Просмотры
    Последнее сообщение Anonymous
  • Вопрос о коде Python для сортировки слиянием [закрыто]
    Anonymous » » в форуме Python
    0 Ответы
    16 Просмотры
    Последнее сообщение Anonymous
  • Попытка реализации сортировки слиянием связанного списка с помощью Python приводит к бесконечному циклу
    Anonymous » » в форуме Python
    0 Ответы
    29 Просмотры
    Последнее сообщение Anonymous
  • Программа Python с использованием сортировки слиянием
    Anonymous » » в форуме Python
    0 Ответы
    12 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Python»