|
0 / 0 / 0
Регистрация: 14.07.2018
Сообщений: 23
|
|
“Сжать” список, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в правую часть26.07.2018, 00:20. Показов 48136. Ответов 47
Метки нет (Все метки)
Дан список целых чисел. Требуется “сжать” его, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в правую часть. Порядок ненулевых элементов изменять нельзя, дополнительный список использовать нельзя, задачу нужно выполнить за один проход по списку. Распечатайте полученный список.
Входные данные Вводится список чисел. Все числа списка находятся на одной строке. Выходные данные Выведите ответ на задачу. Примеры входные данные 4 0 5 0 3 0 0 5 выходные данные 4 5 3 5 0 0 0 0
0
|
|
| 26.07.2018, 00:20 | |
|
Ответы с готовыми решениями:
47
Сжать массив, переместив все ненулевые элементы в левую часть списка, а все нули-в правую часть
Если длина списка нечетна, построить список, поменяв местами левую и правую часть списка |
| 06.08.2020, 09:42 | |||||||
Однако reversed не создает нового списка, а создает итератор.
0
|
|||||||
|
Модератор
|
|||||||
| 06.08.2020, 09:46 | |||||||
|
Viktorrus, да хоспаде, хотите в строчку, держите:
0
|
|||||||
| 06.08.2020, 10:19 | ||||||||
|
DmFat, Кстати map тоже создает итератор, а не список.
В общем на усмотрение TC , сочтет он итераторы не допустимыми по условию или нет. в принципе формально итератор это не список. Что бы получить из него список нужно к нему применить list() Добавлено через 9 минут
Вообще то формально мы по условию не должны создавать ни одного списка, а ивпользовать только строку которую мы получаем при вводе и которая в условии называется списком. ![]() split() тоже использовать нельзя, так как он возвращает список. Просто условие написано по дурацки. Нужно было писать, что вводится последовательность чисел и при решении можно использовать только один список. Вобщем ТС пусть решает, как он будет выкручиваться. ![]() Добавлено через 3 минуты Или в условии нужно было написать, что при решении нельзя использовать списки. И тогда пришлось бы работать только со строковыми операциями. Срезы и конкатенации. Добавлено через 7 минут DmFat, А вообще, как я подозреваю, те, кто писал условие, подразумевали, что нельзя создавать дополнительный список, куда перегонять числа из начального списка, а только преобразовывать исходный список который формируется из строки при вводе данных. Просто они не четко написали условие.
0
|
||||||||
| 06.08.2020, 10:27 | ||
|
DmFat, А вообще я что то нарушил свой принцип, не браться за задания, где вводят ограничение на использование средств питона. Считаю, что это глупо. Нужно учиться писать программы используя все существующие средства питона, а так же сторонние библиотеки, без ограничений.
Добавлено через 2 минуты
0
|
||
|
Супер-модератор
|
||||||
| 06.08.2020, 10:40 | ||||||
|
И без затей, за один проход:
0
|
||||||
|
Модератор
|
||||||
| 06.08.2020, 10:59 | ||||||
|
Catstail, с вашего позволения:
1
|
||||||
|
Модератор
|
|||||||||||
| 06.08.2020, 11:24 | |||||||||||
|
А просто любопытно, почему применяются явно неэффективные решения с выделениями дополнительной памяти, сортировкой и прочими радостями жизни вместо простого варианта
Или скриптовый Python быстрее обработает однострочную функцию, чем многострочный циклический алгоритм? Т.е. существуют особенности реализации языка? Добавлено через 3 минуты Пока изучал язык, подобные решения тоже привели...
1
|
|||||||||||
|
Модератор
|
|||||||||||
| 06.08.2020, 13:22 | |||||||||||
|
ФедосеевПавел,
Более правильный пример:
1
|
|||||||||||
|
Модератор
|
|||||||||||||||||||||
| 06.08.2020, 14:30 | |||||||||||||||||||||
|
Не разобрался, как в онлайн-компиляторе подключить @benchmark и StressTestsTools
Поэтому воспользовался https://stackoverflow.com/ques... hon-script
https://rextester.com/l/python3_online_compiler результаты меняются и не могу увеличить количество тестов - система "убивает" процесс. Но результаты не столь удручающи
0
|
|||||||||||||||||||||
|
Модератор
|
|||||||||||||||||||||
| 06.08.2020, 15:36 | |||||||||||||||||||||
|
ФедосеевПавел, не получилось, потому что это мои личные модули, извиняюсь что не указал этого.
Тут дела вкуса, для меня проще когда кода меньше. Кому то наоборот, надо сильнее разжевывать код для понимания. Например создание двумерного массива заполненного нулями, красивее и более понятно выглядит, вот так:
Еще пример:
1
|
|||||||||||||||||||||
|
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
|
|
| 06.08.2020, 15:52 | |
|
0
|
|
|
|
||
| 06.08.2020, 16:40 | ||
|
По моим тестам ваш вариант в 1.5 раза медленнее встроенной сортировки на 100_000 списке.
0
|
||
|
Модератор
|
||||||
| 06.08.2020, 16:45 | ||||||
|
Который вариант - первый или второй?
Второй - в общем-то быстрее тех алгоритмов, что сравнивались в сообщении 33
0
|
||||||
|
|
||
| 06.08.2020, 16:49 | ||
|
0
|
||
|
Модератор
|
|
| 06.08.2020, 16:51 | |
|
А если такой такой разброс в скорости - 1,5 раза - то чем объяснить?
Ведь в моём коде нет лишних операций - поиск первого нуля и дальнейший перенос ненулевых элементов. В разных условиях может оказаться, что заполнение нулями не в цикле, а в конце отдельной строкой будет быстрее. Но при сортировке такой оптимальности не будет - будет обмен значениями.
1
|
|
| 06.08.2020, 16:51 | |
|
Помогаю со студенческими работами здесь
40
Задан массив, содержащий несколько нулевых элементов. Требуется "сжать" его, переместив нулевые элементы в правую часть Перенести все числа больше нуля в правую часть массива, остальные в левую
Перенести все нулевые элементы в правую часть матрицы
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes.
А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения
развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам
Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
|
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11
Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|