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

Упорядочить числа a, b, c, d по убыванию

17.03.2021, 19:06. Показов 2102. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Упорядочить числа a, b, c, d по убыванию
на языке Python
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.03.2021, 19:06
Ответы с готовыми решениями:

Упорядочить массив: сначала идут отрицательные числа, упорядоченные по убыванию, потом положительные
Дан массив x размера n = 10 целых чисел, содержащий как положительные, так и отрицательные элементы. Упорядочить массив следующим образом:...

Упорядочить массив: сначала идут отрицательные числа, упорядоченные по убыванию, потом положительные
Дан массив x размера n = 10 целых чисел, содержащий как положительные, так и отрицательные элементы. Упорядочить массив следующим образом:...

Упорядочить массив по убыванию
Задан одномерный массив NAME псевдослучайных вещественных чисел. Упорядочить массив по убыванию. В сортировке участвуют только каждый...

9
 Аватар для Semen-Semenich
5237 / 3481 / 1176
Регистрация: 21.03.2016
Сообщений: 8,309
17.03.2021, 20:27
sort()
0
 Аватар для Damenikx
955 / 341 / 114
Регистрация: 04.08.2018
Сообщений: 2,533
18.03.2021, 16:03
Python
1
2
list_for_sort = [22,1,453,66]
print(sorted(list_for_sort, reverse=True))
1
99 / 86 / 20
Регистрация: 10.09.2019
Сообщений: 708
18.03.2021, 17:42
При небольшом количестве значений и почти отсортированных списках
сортировка вставками эффективнее функции sorted() с её алгоритмом timsort.
На практике лучше применять функцию sorted().
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
#-*- coding: utf-8 -*-
"""
*.py - name file
"""
import time
list_for_sort = [22,1,453,66]
 
start = time.perf_counter_ns()
print(sorted(list_for_sort, reverse=True))
stop = time.perf_counter_ns()
print(stop-start)
 
def insertion(data):
    """
    Сортировка вставками при малых значениях
    """
    for i in range(len(data)):
        j = i - 1
        key = data[i]
        while data[j] > key and j >= 0:
            data[j + 1] = data[j]
            j -= 1
        data[j + 1] = key
    return data
 
start = time.perf_counter_ns()
insertion(list_for_sort)
stop = time.perf_counter_ns()
print(stop-start)
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
18.03.2021, 19:50
Цитата Сообщение от AlexMarkov Посмотреть сообщение
При небольшом количестве значений и почти отсортированных списках
сортировка вставками эффективнее функции sorted() с её алгоритмом timsort.
- и Вы можете это доказать?
0
99 / 86 / 20
Регистрация: 10.09.2019
Сообщений: 708
18.03.2021, 19:54
Цитата Сообщение от Catstail Посмотреть сообщение
- и Вы можете это доказать?
Критерий "достаточной малости" зависит от конкретной машины и языка программирования.
В действительности может играть роль даже тип сравниваемых элементов.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
18.03.2021, 19:59
Ваш код измеряет не то, что Вы предполагаете... Вы печатает результат sorted, но ведь print - весьма затратная функция. А вот в коде сортировки вставками Вы print не вызываете. Если восстановить справедливость, то :

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
import time
list_for_sort = [22,1,453,66]
 
start = time.perf_counter_ns()
zz=sorted(list_for_sort, reverse=True)
stop = time.perf_counter_ns()
print(stop-start)
 
def insertion(data):
    """
    Сортировка вставками при малых значениях
    """
    for i in range(len(data)):
        j = i - 1
        key = data[i]
        while data[j] > key and j >= 0:
            data[j + 1] = data[j]
            j -= 1
        data[j + 1] = key
    return data
 
start = time.perf_counter_ns()
insertion(list_for_sort)
stop = time.perf_counter_ns()
print(stop-start)
Вывод:

Успешно #stdin #stdout 0.02s 9212KB
2761
4237

Успешно #stdin #stdout 0.02s 9152KB
2895
4050

PS
Кстати, при тестировании лучше запускать несколько раз и усреднять.
1
99 / 86 / 20
Регистрация: 10.09.2019
Сообщений: 708
18.03.2021, 20:05
Эффективность сортировки вставками уве­личивается при наличии одинаковых элементов,
поскольку при этом требуется вы­полнять меньше обменов.
На доказательства нет времени, авторы по опытнее меня будут)
Цитата Сообщение от Catstail Посмотреть сообщение
Кстати, при тестировании лучше запускать несколько раз и усреднять.
Спасибо, условия слишком просты не обратил внимание на print().
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
18.03.2021, 20:07
Цитата Сообщение от AlexMarkov Посмотреть сообщение
Эффективность сортировки вставками уве­личивается при наличии одинаковых элементов,
- эффективность сортировки вставками увеличивается при малом числе инверсий (когда массив уже почти отсортирован). Это называется "естественность". Загляните https://www.cyberforum.ru/blog... g6808.html
2
99 / 86 / 20
Регистрация: 10.09.2019
Сообщений: 708
18.03.2021, 20:26
Цитата Сообщение от AlexMarkov Посмотреть сообщение
сортировка вставками эффективнее функции sorted() с её алгоритмом timsort
Прошу прощения если кто-то здесь заблудился) и читает этот пост, рассматриваю данный форум, как хорошую "площадочку", чтобы поднабраться опыта
Catstail, спасибо, очень хорошая статья, на днях прочитаю повнимательнее.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.03.2021, 20:26
Помогаю со студенческими работами здесь

Упорядочить элементы массива по убыванию модулей
В одномерном массиве, состоящем из п вещественных элементов, вычислить: Упорядочить элементы массива по убыванию модулей.

Выбрать данные о проводниках и упорядочить по убыванию плотности
Создать файл, содержащий данные о веществах: название, плотность, проводимость. а)выбрать данные о проводниках и упорядочить по...

Упорядочить всю последовательность животных по убыванию количества пищи
всем привет, выскочил вопрос по заданию, помогите с вот этими пунктами: a) Упорядочить всю последовательность животных по убыванию...

Упорядочить по убыванию элементы целочисленного массива, расположенные после минимального числа-палиндрома
Доброго времени суток!!! Пожалуйста помогите. Упорядочить по убыванию элементы целочисленного массива, расположенные после минимального...

Упорядочить массив из N элементов по убыванию
Упорядочить массив из N элементов по убыванию, найти k1 – количество положительных, k2 – количество отрицательных, k3 – количество нулевых...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru