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

Все отрицательные элементы разместить в конце массива, все положительные упорядочить по возрастанию

14.03.2020, 21:24. Показов 5201. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
3. В одномерном массиве все отрицательные элементы разместить в конце массива, все положительные упорядочить по возрастанию.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.03.2020, 21:24
Ответы с готовыми решениями:

Переставить элементы так, чтобы все положительные стояли в начала массива, а все отрицательные и нули – в конце
Суть программы: Заполнить массив случайными числами в интервале и переставить элементы так, чтобы все положительные элементы стояли в...

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

Разместить в массиве все положительные элементы в начале, отрицательные - в конце, посередине - нули
Всем доброго времени суток! Большая просьба помочь написать программу. Нужно сформировать 2 одинаковых динамических одномерных массива, где...

6
 Аватар для codcw
815 / 527 / 214
Регистрация: 22.12.2017
Сообщений: 1,495
15.03.2020, 00:11
Лучший ответ Сообщение было отмечено Stad08 как решение

Решение

Python
1
print(sorted(list(filter(lambda x:x>0,a)))+list(filter(lambda x:x<0,a)))
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
15.03.2020, 02:28
Если уж использовать встроенные средства, то банально вот так:
Python
1
2
3
4
5
6
>>> arr = [random.randint(-100,100) for i in range(10)]
>>> arr
[-90, 35, -76, -43, -83, 39, -76, 45, 88, 89]
>>> sorted(arr, key=lambda k: k>0,reverse=True)
[35, 39, 45, 88, 89, -90, -76, -43, -83, -76]
>>>
Добавлено через 7 минут
Ну или как в примере выше (только вручную) раскидать элементы на два списка: отрицательные и положительные.
Отсортировать любой сортировкой список с положительными. Слить оба списка в один.
Чего-то более алгоритмически умного не придумалось...
1
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
15.03.2020, 13:34
Цитата Сообщение от Garry Galler Посмотреть сообщение
банально вот так
Неверно. Не работает так. Оказывается, просто случайно совпало, что список положительных отсортированный получился.
Значит, все-таки делить на два списка...

Semen-Semenich, убирай плюс...
1
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
15.03.2020, 15:00
Лучший ответ Сообщение было отмечено Stad08 как решение

Решение

Garry Galler,
Python
1
print(sorted(arr, key=lambda k: math.inf if k < 0 else k))
2
 Аватар для Semen-Semenich
5236 / 3480 / 1176
Регистрация: 21.03.2016
Сообщений: 8,307
15.03.2020, 15:55
Цитата Сообщение от Garry Galler Посмотреть сообщение
Неверно. Не работает так
а по логике вроде должно.
1
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
15.03.2020, 16:11
Цитата Сообщение от Semen-Semenich Посмотреть сообщение
по логике вроде должно.
sorted по такому ключу просто делит (по сути сортирует) список на две половины: c положительными и отрицательными элементами (тоже, конечно, полезный кейс), но сами элементы в этих половинках более никак не сортирует.
Python
1
2
3
4
5
6
7
8
>>> arr = [random.randint(-100,100) for i in range(20)]
>>> arr
[85, -25, 16, 10, -2, 58, -71, -5, -65, 55, 78, 44, 99, -49, 15, -41, 10, -89, 9, -70]
>>> sorted(arr, key=lambda k: k>0,reverse=True)
[85, 16, 10, 58, 55, 78, 44, 99, 15, 10, 9, -25, -2, -71, -5, -65, -49, -41, -89, -70]
>>> sorted(arr, key=lambda k: k>0)
[-25, -2, -71, -5, -65, -49, -41, -89, -70, 85, 16, 10, 58, 55, 78, 44, 99, 15, 10, 9]
>>>
Добавлено через 4 минуты
А вот по ключу eea все как раз работает.
Так что плюс в карму ему.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.03.2020, 16:11
Помогаю со студенческими работами здесь

Переставить элементы, чтобы все положительные элементы стояли в начале массива, а все отрицательные и нули - в конце
«C»: Заполнить массив случайными числами в интервале и переставить элементы так, чтобы все положительные элементы стояли в начала...

Перенести в начало массива все его отрицательные элементы, затем нулевые и в конце все положительные
Перенести в начало массива А(n) все его отрицательные элементы, затем нулевые и в конце все положительные.(числа должны остаться в том...

Разместить сначала все положительные элементы массива, а затем все отрицательные и нули, сохраняя порядок их следования
Дан массив вещественных чисел, содержащий 20 элементов. Записать в этот же массив сначала все положительные числа, а затем все...

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

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru