Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 27.02.2019
Сообщений: 42

Сортировка слиянием

27.02.2019, 13:14. Показов 2092. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать функцию, которая принимает на вход любой массив/список и выдает все промежуточные списки, которые получаются в процедуре MergeSort от самого нижнего уровня до отсортированного массива в конце.
Тоесть сначала нужно выдать список, в котором отсортирована каждая пара, затем список, в котором отсортирована каждая четверка, и так далее, пока не дойдем до полностью отсортированного массива.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.02.2019, 13:14
Ответы с готовыми решениями:

Сортировка слиянием
Помогите, пожалуйста, с ошибкой File "Untitled3.py", line 43, in <module> print(*merge_sort(a)) TypeError: print() argument...

Сортировка слиянием
Нужно создать код (сортировка слиянием). Подойдёт ли этот? def merge_sort(alist, start, end): '''Sorts the list from indexes start...

Сортировка слиянием
Всем здравствуйте, пытаюсь реализовать алгоритм сортировки массива, но не понимаю что в моем коде не верно. def...

2
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38196 / 21129 / 4309
Регистрация: 12.02.2012
Сообщений: 34,737
Записей в блоге: 14
27.02.2019, 14:08
Лучший ответ Сообщение было отмечено Defaultinge как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
def mergeArr(a,b):
    la=len(a)
    lb=len(b)
    r=[]
    ia=ib=0
    while(True):
        if (ib>=lb):
            for ja in range(ia,la):
                r+=[a[ja]]
            break
        if (ia>=la):
            for jb in range(ib,lb):
                r+=[b[jb]]
            break
        if (a[ia]>b[ib]):
            r+=[b[ib]]
            ib+=1
        else:
            r+=[a[ia]]
            ia+=1
    return r
    
def mkA(arr):
    r=[]
    for a in arr:
        r+=[[a]]
    return r
    
def mergeSort(arr):
    tmp=mkA(arr)
    while(True):
        res=[]
        print(str(tmp))
        l=len(tmp)
        if l==1:
            return tmp[0]
        i=0
        while (i+1<=l-1):
            res+=[mergeArr(tmp[i],tmp[i+1])]
            i+=2
        if i==l-1:
            res+=[tmp[l-1]]
        tmp=res
 
x=mergeSort([1,2,3,1,2,3,1,2,3,1,2,4,1,2,5])
print(str(x))

Code
1
2
3
4
5
6
[[1], [2], [3], [1], [2], [3], [1], [2], [3], [1], [2], [4], [1], [2], [5]]
[[1, 2], [1, 3], [2, 3], [1, 2], [1, 3], [2, 4], [1, 2], [5]]
[[1, 1, 2, 3], [1, 2, 2, 3], [1, 2, 3, 4], [1, 2, 5]]
[[1, 1, 1, 2, 2, 2, 3, 3], [1, 1, 2, 2, 3, 4, 5]]
[[1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 3, 3, 3, 4, 5]]
[1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 3, 3, 3, 4, 5]

https://ideone.com/xJXNlw
1
Эксперт Python
1356 / 653 / 207
Регистрация: 23.03.2014
Сообщений: 3,057
27.02.2019, 14:44
Сортировка слияниями
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.02.2019, 14:44
Помогаю со студенческими работами здесь

Сортировка слиянием
def merge(l: list, r: list): c = * (len(l) + len(r)) i = k = n = 0 while i &lt; len(l) and k &lt; len(r): if l &lt;= r:...

Сортировка слиянием
Помогите разобраться, почему не работает. Написал сортировку слиянием через 2 функции: одна сортирует и объединяет списки, другая дробит...

Сортировка слиянием
Помогите пожалуйста! Нужно написать программу, выполняющую сортировку слиянием с описанием каждой строки, чтобы она выполняла сортировку...

Сортировка слиянием из файла
Нашел на просторах форума данный код и дополнил так, что бы он брал числа из файла def mergeSort(alist): if len(alist)&gt;1: ...

Сортировка слиянием на языке Питон
Помогите пожалуйста. Я никогда не работал с языком питон. помогите написать сортировку слиянием размерность сортируемой последовательности...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru