0 / 0 / 0
Регистрация: 14.07.2018
Сообщений: 23

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

26.07.2018, 00:20. Показов 49964. Ответов 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
5438 / 3859 / 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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8665 / 4502 / 1670
Регистрация: 01.02.2015
Сообщений: 13,931
Записей в блоге: 13
06.08.2020, 17:05
Получается, что "полная пошаговая роспись алгоритма" будет медленно интерпретироваться, а использование "казалось бы неоптимального" алгоритма (применение избыточных типов данных, избыточных функций) на встроенных средствах - быстро выполняться нативным для процессора кодом.
Ясно.

Спасибо.
0
Эксперт Python
5438 / 3859 / 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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8665 / 4502 / 1670
Регистрация: 01.02.2015
Сообщений: 13,931
Записей в блоге: 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
130 / 126 / 19
Регистрация: 05.08.2021
Сообщений: 556
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__
2760 / 2067 / 509
Регистрация: 17.02.2014
Сообщений: 9,494
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
264 / 38 / 8
Регистрация: 03.02.2025
Сообщений: 142
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
130 / 126 / 19
Регистрация: 05.08.2021
Сообщений: 556
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru