Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
4 / 3 / 1
Регистрация: 01.11.2019
Сообщений: 4

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

17.02.2022, 14:56. Показов 663. Ответов 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
38168 / 21103 / 4307
Регистрация: 12.02.2012
Сообщений: 34,691
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru