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

“Сжать” список, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в правую часть

26.07.2018, 00:20. Показов 50375. Ответов 52
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан список целых чисел. Требуется “сжать” его, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в правую часть. Порядок ненулевых элементов изменять нельзя, дополнительный список использовать нельзя, задачу нужно выполнить за один проход по списку. Распечатайте полученный список.

Входные данные
Вводится список чисел. Все числа списка находятся на одной строке.

Выходные данные
Выведите ответ на задачу.

Примеры
входные данные
4 0 5 0 3 0 0 5
выходные данные
4 5 3 5 0 0 0 0
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.07.2018, 00:20
Ответы с готовыми решениями:

Сжать массив, переместив все ненулевые элементы в левую часть списка, а все нули-в правую часть
Дан список целых чисел. Требуется “сжать” его, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в...

Сжать список, переместив все ненулевые элементы в левую часть, не меняя их порядок
Дан список целых чисел. Требуется “сжать” его, переместив все ненулевые элементы в левую часть списка, не меняя их порядок, а все нули - в...

Если длина списка нечетна, построить список, поменяв местами левую и правую часть списка
Дан список L. Если длина списка нечетна, построить список L1, поменяв местами левую и правую часть списка, в противном случае оставить...

52
Эксперт Python
5439 / 3860 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
06.08.2020, 16:57
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
такой разброс в скорости - 1,5 раза - то чем объяснить?
Python циклы не самые (мягко говоря) быстрые во вселенной программирования.
Поэтому для более эффективной работы с последовательностями в Python существуют встроенные функции, которые работают на порядок эффективнее: sort/map/filter и и т.д.
И надо заметить, что питоновски sort (TimSort) на самом деле еще быстрее. Но только не на полном рандоме, который мы тут ему даем, а на частично отсортированных данных, которые в жизни встречаются чаще.
На полном рандоме быстрее будет quick_sort.
1
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
06.08.2020, 16:58
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
Но при сортировке такой оптимальности не будет - будет обмен значениями
Если я не ошибаюсь сортировка в питоне написана на Си и поэтому работает значительно быстрее.
1
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8671 / 4508 / 1670
Регистрация: 01.02.2015
Сообщений: 13,936
Записей в блоге: 13
06.08.2020, 17:05
Получается, что "полная пошаговая роспись алгоритма" будет медленно интерпретироваться, а использование "казалось бы неоптимального" алгоритма (применение избыточных типов данных, избыточных функций) на встроенных средствах - быстро выполняться нативным для процессора кодом.
Ясно.

Спасибо.
0
Эксперт Python
5439 / 3860 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
06.08.2020, 17:16
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
"полная пошаговая роспись алгоритма" будет медленно интерпретироваться
Да, такова суть динамических интерпретируемых языков. Интерпретатор проверяет тип переменной на каждом шаге ее использования. Поэтому в математич. библиотеке numpy (написанной, естественно, на Python-Си-API) существует собственный векторный язык работы с числовыми массивами - и применение Python циклов и функций там вообще ограничено только разовыми вызовами, чтобы не замедлять исполнение машинного кода.
1
964 / 719 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
07.08.2020, 02:16
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
Получается, что "полная пошаговая роспись алгоритма" будет медленно интерпретироваться, а использование "казалось бы неоптимального" алгоритма (применение избыточных типов данных, избыточных функций) на встроенных средствах - быстро выполняться нативным для процессора кодом.
не совсем так. для сортировки "на месте" нужна минимум одна временная переменная для свопа двух значений. в Си массивы однородные, доступ через указатель, никаких рантаймовых проверок нет - все проверяет прогер когда пишет. поэтому и скорость выше
1
964 / 719 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
07.08.2020, 19:45
если интересно - гляньте
https://ru.wikibooks.org/wiki/... Сортировка
классика
1
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8671 / 4508 / 1670
Регистрация: 01.02.2015
Сообщений: 13,936
Записей в блоге: 13
07.08.2020, 22:12
Спасибо.
По сортировке qsort похожее видел для msvcrt.
По ссылке с интересом почитал о необычных рекурсивных решениях других задач.
0
964 / 719 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
07.08.2020, 23:17
Дональд Кнут в "Искусстве программирования" 3 том посвятил именно сортировке и поиску.
тут интересный обзор
1
 Аватар для KoolMouser
2 / 2 / 0
Регистрация: 07.02.2026
Сообщений: 7
21.02.2026, 13:41
код семена семеныча, только более стандартном формате и без reversed:
Python
1
2
3
4
5
6
a = list(map(int, input().split()))
for i in range(len(a)-1,-1,-1):
    if a[i] == 0:
        a.append(a.pop(i))
for i in a:
    print(i, end=' ')
0
133 / 129 / 20
Регистрация: 05.08.2021
Сообщений: 593
23.02.2026, 17:23
Python
1
2
s = '4 0 5 0 3 0 0 5'.split(' ')
print(list(filter(lambda x: int(x),s)) + list(filter(lambda x: not int(x),s)))
['4', '5', '3', '5', '0', '0', '0', '0']
0
 Аватар для Aviz__
2762 / 2069 / 510
Регистрация: 17.02.2014
Сообщений: 9,502
24.02.2026, 21:19
классика с двумя указателями (геронтофилам посвящаю):
Python
1
2
3
4
5
6
7
8
arr = [0, 1, 0, 3, 12]
j = 0
for i in range(len(arr)):
    if arr[i] != 0:
        arr[j], arr[i] = arr[i], arr[j]
        j += 1
 
print(arr)
0
271 / 44 / 10
Регистрация: 03.02.2025
Сообщений: 157
24.02.2026, 22:14
Цитата Сообщение от Aviz__ Посмотреть сообщение
Python
1
2
3
4
5
6
7
arr = [0, 1, 0, 3, 12]
j = 0
for i in range(len(arr)):
    if arr[i] != 0:
        arr[j], arr[i] = arr[i], arr[j]
        j += 1
print(arr)
А это что пузырьковый алгоритм что ли? Или только похож на него?
0
133 / 129 / 20
Регистрация: 05.08.2021
Сообщений: 593
06.04.2026, 11:24
Python
1
2
3
4
5
try:
    s = input().split(' ')
    print(*list(map(int,list(filter(lambda x: int(x),s)) + list(filter(lambda x: not int(x),s)))))
except ValueError:
    print('error')
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.04.2026, 11:24

Задан массив, содержащий несколько нулевых элементов. Требуется "сжать" его, переместив нулевые элементы в правую часть
Здравствуйте! Помогите пожалуйста решить задачу Я по факту знаю как ее решать, но прога работает бесконечно :cry: %-) Помогите...

Перенести все числа больше нуля в правую часть массива, остальные в левую
Вот примерно что получилось. void Masiv::zamina(int nn) { for (int i=0;i<nn;i++) { if (g<0) { z=-1; ...

Поменять левую и правую часть списка местами
Дан список I и числа k1 и k2 (k1<k2)- позиций в списке, разбивающие список на три части. Поменять левую и правую часть списка местами

Перенести все нулевые элементы в правую часть матрицы
Помогите решить задача: Все нулевые элементы размещены в правой части матрицы. c++ Добавлено через 56 минут пример, тут вывод на...

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


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

Или воспользуйтесь поиском по форуму:
53
Ответ Создать тему
Новые блоги и статьи
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы ### Аннотация Представлено исследование по разработке агентной модели микоризной. . .
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru