Я изучал «Введение в алгоритмы» на открытом курсе MIT и запутался в коде сортировки слиянием. Я думал, что код не может добавить L или R[j] в набор О.
Я пытался проанализировать код, включая рекурсивную часть. Я думал, что это только делает A[b-1] = L[j-1] или R[j-1] и рекурсивно присваивает каждый элемент в A[:b-1], но нет оператора для присвоения L или R[j] на A, возможно, это мое неправильное мнение.
Вот код.
def merge_sort(A, a = 0, b = None): # T(b - a = n)
'''Sort A[a:b]'''
if b is None: b = len(A) # O(1)
if 1 < b - a: # O(1)
c = (a + b + 1) // 2 # O(1)
merge_sort(A, a, c) # T(n / 2)
merge_sort(A, c, b) # T(n / 2)
L, R = A[a:c], A[c:b] # O(n)
merge(L, R, A, len(L), len(R), a, b)# S(n)
def merge(L, R, A, i, j, a, b): # S(b - a = n)
'''Merge sorted L[:i] and R[:j] into A[a:b]'''
if a < b: # O(1)
if (j 0 and L[i - 1] > R[j - 1]): # O(1)
A[b - 1] = L[i - 1] # O(1)
i = i - 1 # O(1)
else: # O(1)
A[b - 1] = R[j - 1] # O(1)
j = j - 1 # O(1)
merge(L, R, A, i, j, a, b - 1) # S(n - 1)
Я был бы признателен, если бы кто-нибудь помог мне решить эту проблему.
Я изучал «Введение в алгоритмы» на открытом курсе MIT и запутался в коде сортировки слиянием. Я думал, что код не может добавить L[i] или R[j] в набор О. Я пытался проанализировать код, включая рекурсивную часть. Я думал, что это только делает A[b-1] = L[j-1] или R[j-1] и рекурсивно присваивает каждый элемент в A[:b-1], но нет оператора для присвоения L[i ] или R[j] на A[b], возможно, это мое неправильное мнение. Вот код. [code]def merge_sort(A, a = 0, b = None): # T(b - a = n) '''Sort A[a:b]''' if b is None: b = len(A) # O(1) if 1 < b - a: # O(1) c = (a + b + 1) // 2 # O(1) merge_sort(A, a, c) # T(n / 2) merge_sort(A, c, b) # T(n / 2) L, R = A[a:c], A[c:b] # O(n) merge(L, R, A, len(L), len(R), a, b)# S(n)
def merge(L, R, A, i, j, a, b): # S(b - a = n) '''Merge sorted L[:i] and R[:j] into A[a:b]''' if a < b: # O(1) if (j 0 and L[i - 1] > R[j - 1]): # O(1) A[b - 1] = L[i - 1] # O(1) i = i - 1 # O(1) else: # O(1) A[b - 1] = R[j - 1] # O(1) j = j - 1 # O(1) merge(L, R, A, i, j, a, b - 1) # S(n - 1) [/code] Я был бы признателен, если бы кто-нибудь помог мне решить эту проблему.
В алгоритме сортировки слиянием мы используем рекурсию для левой и правой частей, массив делится рекурсивно до тех пор, пока размер подмассива не станет равным 1. После разделения подмассивов я узнал, что левый и правый подмассивы сортируются и...
Я изучал «Введение в алгоритмы» на открытом курсе MIT и запутался в коде сортировки слиянием. Не кажется ли, что L или R добавлены в набор A?
Вот код.
def merge_sort(A, a = 0, b = None): # T(b - a = n)
'''Sort A '''
if b is None: b = len(A) # O(1)...
Контекст
Я реализовал решение для сортировки LinkedList с помощью Python (на сайте leetcode.com).
Решение представляет собой подход сортировки слиянием снизу вверх (разделяй и властвуй). .
Приведенный ниже код неполон, в нем отсутствует реализация...
Она должна содержать еще одну функцию, которая подсчитывает, сколько сравнений было выполнено и сколько дополнительных списков было создано во время последнего запуска функции сортировки.
Затем мне нужно реализовать цветные изображения как списки...