4 / 3 / 1
Регистрация: 01.11.2019
Сообщений: 4

Создание отсортированного списка без алгоритмов сортировки

17.02.2022, 14:56. Показов 682. Ответов 3

Студворк — интернет-сервис помощи студентам
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
def qwerty(a, b, c): #реализация без сортировки
    x = len(a)
    y = len(b)
    i = 0
    j = 0
    while i < x:
        while j < y:
            if a[i] > b[j]:
                c.append(a[i])
                i += 1
            elif a[i] < b[j]:
                c.append(b[j])
                j += 1
            elif a[i] == b[j]:
                c.append(a[i])
                c.append(b[j])
                i += 1
                j += 1
    print(c)       
 
b = [10, 9, 3]
a = [6, 5, 4, 1, 0]
c = []
#input_arr(a)
#input_arr(b)
qwerty(a, b, c)
Нужно из двух уже отсортированных в убывающем порядке массивов получить новый массив, отсортированный в убывающем порядке и состоящий из элементов обоих массивов. Я не понимаю, что у меня не так и почему он не работает. Код выше - моя попытка переписать программу полностью, но она не выдаёт вообще ничего.
Кусок кода ниже работает, но не полностью - когда заканчивается один из списков, работа цикла заканчивается и я не знаю, как мне сделать так, чтобы он работал дальше.

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
def qwerty(a, b, c): #реализация без сортировки
    x = len(a)
    y = len(b)
    i = 0
    j = 0
    while i < x and j < y:
        if b[j] < a[i]:
            c.append(a[i])
            i += 1
        elif a[i] < b[j]:
            c.append(b[j])
            j += 1
        elif a[i] == b[j]:
            c.append(a[i])
            c.append(b[j])
            i += 1
            j += 1
    print(c)
    if a[x-1] > b[y-1]:
        c.append(b[y-1])
    elif a[x-1] < b[y-1]:
        c.append(a[x-1])
b = [10, 9, 3]
a = [6, 5, 4, 1, 0]
c = []
#input_arr(a)
#input_arr(b)
qwerty(a, b, c)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.02.2022, 14:56
Ответы с готовыми решениями:

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

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

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

3
2431 / 1474 / 633
Регистрация: 01.11.2021
Сообщений: 2,269
17.02.2022, 16:01
Можно так подправить
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
def qwerty(a, b, c):  # реализация без сортировки
    x = len(a)
    y = len(b)
    i = 0
    j = 0
    while i < x or j < y:
        if i == x and j <= y:
            c.extend(b[j:y])
            break
        elif i < x and j >= y:
            c.extend(a[i:x])
            break
        if b[j] < a[i]:
            c.append(a[i])
            i += 1
        elif a[i] < b[j]:
            c.append(b[j])
            j += 1
        elif a[i] == b[j]:
            c.append(a[i])
            c.append(b[j])
            i += 1
            j += 1
    print(c)
    if a[x - 1] > b[y - 1]:
        c.append(b[y - 1])
    elif a[x - 1] < b[y - 1]:
        c.append(a[x - 1])
 
 
b = [10, 9, 3]
a = [6, 5, 4, 1, 0]
c = []
# input_arr(a)
# input_arr(b)
qwerty(a, b, c)
Добавлено через 12 минут
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def merge_two_lists(l1, l2):
    if not l1:
        return l2
    if not l2:
        return l1
 
    if (l1[0] >= l2[0]):
        return [l1[0]] + merge_two_lists(l1[1:], l2)
    else:
        return [l2[0]] + merge_two_lists(l2[1:], l1)
 
 
a = [6, 5, 4, 1, 0]
b = [10, 9, 3]
print(merge_two_lists(a, b))
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38175 / 21110 / 4307
Регистрация: 12.02.2012
Сообщений: 34,712
Записей в блоге: 14
17.02.2022, 16:28
menayttta, лишние действия...

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
def merge(list1,list2):
    res=[]
    i1=i2=0
    while True:
        if i1 >= len(list1):
            res.extend(list2[i2:])
            break
        if i2 >= len(list2):
            res.extend(list1[i1:])
            break
        if list1[i1]<list2[i2]:
            res.append(list2[i2])
            i2+=1
        else:    
            res.append(list1[i1])
            i1+=1
    return res
    
a = [6, 5, 4, 1, 0]
b = [10, 9, 3]
 
print(merge(a,b))
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
17.02.2022, 17:04
В принципе, Catstail, все написал...
но все-таки закину похожий вариант - поэтому что он чуть-чуть более питоничный:

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
def merge(left,right):
    '''слияние отсортированных массивов'''
    
    i,j = 0,0
    out = []
    
    while i < len(left) and j < len(right):
        #  по убыванию
        if left[i] > right[j]:
            out.append(left[i])
            i += 1
        else:
            out.append(right[j])
            j += 1
    
    # дозаписываем остаток
    if i < len(left):
        out.extend(left[i:])
       
    # дозаписываем остаток
    if j < len(right):
        out.extend(right[j:])
        
    return out
Python
1
2
3
4
5
6
7
8
9
10
11
left, right = [1,1,1,1],[0, 0, 0]    
print(merge(left,right))
 
left, right = [9,8,7,6,5,4,3,2,1],[0]    
print(merge(left,right))
 
left, right = [9,8,7,6],[5,4,3,2,1,0]  
print(merge(left,right))
 
left, right = [5,4,3,2,1],[5,4,3,2,1]  
print(merge(left,right))
Code
1
2
3
4
[1, 1, 1, 1, 0, 0, 0]
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
[5, 5, 4, 4, 3, 3, 2, 2, 1, 1]
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.02.2022, 17:04
Помогаю со студенческими работами здесь

Вывод отсортированного массива 2-мя методами сортировки
Пишу на Ideone, задание состояло в сортировке массива 2-мя способами, в моем случае выбором и обменом, выводит как бы без ошибок, но сами...

Вывод отсортированного массива с индексами элементов до сортировки
ЗАДАЧА: известны номера пловцов от 0 до n. Необходимо определить по результатам соренований, какое место занял каждый спортсмен. Считается,...

Определить (без сортировки), или растут ли элементы списка
В текстовом файле находятся числа. Сформировать из них список. Определить (без сортировки), или растут его элементы. Результат вывести на...

Сгруппировать двойки, нули и единицы списка без сортировки.
Помогите,пожалуйста, требуется решить задачу c помощью рекурсии без использования &amp;optional, initional element. В числовом списке...

Реализация Алгоритмов Сортировки :Программа с процедурами сортировки простого выб
Помогите для чего нужна это программа и как она работает. (Просто не могу обьяснить преподу). program Project_Sort; const ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru