Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.78/225: Рейтинг темы: голосов - 225, средняя оценка - 4.78
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
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.07.2018, 00:20
Ответы с готовыми решениями:

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

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

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

47
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 09:35
Студворк — интернет-сервис помощи студентам
Viktorrus, да, в одном из примеров вы использовали функцию reversed, а не метод листа.
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
06.08.2020, 09:37
Цитата Сообщение от DmFat Посмотреть сообщение
а разве я где то создавал список?
А действительно
Python
1
 sorted(iterable[, key][, reverse]) -> list
Возвращает новый отсортированный список, составленный из элементов итерируемого объекта.
Вот рубка пошла.
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 09:39
Viktorrus, тогда идеальное решение должно выглядеть так:

Python
1
2
3
collection = input().split()
collection.sort(key=lambda x: not int(x))
print(*collection)
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
06.08.2020, 09:42
Цитата Сообщение от DmFat Посмотреть сообщение
Viktorrus, да, в одном из примеров вы использовали функцию reversed
Это Semen-Semenich, использовал, а я повторил. Однако reversed не создает нового списка, а создает итератор.
Python
1
reversed(seq) -> iterator
. А про итераторы формально в условии ничего не говорится.
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 09:46
Viktorrus, да хоспаде, хотите в строчку, держите:

Python
1
print(*collection if (collection := input().split()).sort(key=lambda x: not int(x)) is None else None)
Добавлено через 2 минуты
Цитата Сообщение от Viktorrus Посмотреть сообщение
не создает нового списка, а создает итератор.
Я не к тому создает ли он новый список или нет, а про наличие методов и функций.
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
06.08.2020, 10:19
DmFat, Кстати map тоже создает итератор, а не список.
В общем на усмотрение TC , сочтет он итераторы не допустимыми по условию или нет.

в принципе формально итератор это не список. Что бы получить из него список нужно к нему применить list()

Добавлено через 9 минут
Цитата Сообщение от ioprst Посмотреть сообщение
list.sort возвращает None
Да, я знаю.
Python
1
 list.sort(key=None, reverse=False) -> None
Добавлено через 12 минут
Вообще то формально мы по условию не должны создавать ни одного списка, а ивпользовать только строку которую мы получаем при вводе и которая в условии называется списком.
Цитата Сообщение от lookatthis Посмотреть сообщение
Вводится список чисел. Все числа списка находятся на одной строке.
Но в этом случае задачу нужно решать используя только строковые методы, не применяя ни одного списка.
split() тоже использовать нельзя, так как он возвращает список.
Просто условие написано по дурацки.
Нужно было писать, что вводится последовательность чисел и при решении можно использовать только один список.
Вобщем ТС пусть решает, как он будет выкручиваться.

Добавлено через 3 минуты
Или в условии нужно было написать, что при решении нельзя использовать списки. И тогда пришлось бы работать только со строковыми операциями. Срезы и конкатенации.

Добавлено через 7 минут
DmFat, А вообще, как я подозреваю, те, кто писал условие, подразумевали, что нельзя создавать дополнительный список, куда перегонять числа из начального списка, а только преобразовывать исходный список который формируется из строки при вводе данных. Просто они не четко написали условие.
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 10:22
Viktorrus, там все равно стоит автомат для проверки, так что я не вижу смысла разводить далее эту демагогию.)
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
06.08.2020, 10:27
DmFat, А вообще я что то нарушил свой принцип, не браться за задания, где вводят ограничение на использование средств питона. Считаю, что это глупо. Нужно учиться писать программы используя все существующие средства питона, а так же сторонние библиотеки, без ограничений.

Добавлено через 2 минуты
Цитата Сообщение от DmFat Посмотреть сообщение
там все равно стоит автомат для проверки
К сожалению некоторые ТС не пишут, что задание будет проверяться автоматом. Я за такие задания тоже не берусь. Для меня важно , на выходе мы получаем правильный ответ или нет. А проходит код тесты или нет, меня не интересует.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 14
06.08.2020, 10:40
И без затей, за один проход:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def psort(lst):
    i_from=0
    i_to=0
    n=len(lst)
    while (True):
        if lst[i_from]:
            lst[i_to]=lst[i_from]
            i_to+=1
        i_from+=1
        if (i_from>n-1):
            break
    while(i_to<=n-1):
        lst[i_to]=0
        i_to+=1
        
 
x=[4,0,5,0,3,0,-1,5]
psort(x)
print(x)
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 10:59
Catstail, с вашего позволения:
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
from goto import with_goto
 
 
@with_goto
def psort(lst: list):
    i_from, i_to, n = 0, 0, len(lst)
 
    label .begin
    
    if lst[i_from]:
        lst[i_to] = lst[i_from]
        i_to += 1
    i_from += 1
 
    if i_from < n:
        goto .begin
 
    label .fix
 
    if i_to < n:
        lst[i_to] = 0
        i_to += 1
        goto .fix
 
 
x=[4, 0, 5, 0, 3, 0, -1, 5]
psort(x)
print(x)
1
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8652 / 4487 / 1669
Регистрация: 01.02.2015
Сообщений: 13,894
Записей в блоге: 12
06.08.2020, 11:24
А просто любопытно, почему применяются явно неэффективные решения с выделениями дополнительной памяти, сортировкой и прочими радостями жизни вместо простого варианта
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#python 3.6.9
 
a = [4, 0, 5, 0, 3, 0, 0, 5]
l=8
#вывод на экран исходного массива
for i in range(l):
    print("%3d" % (a[i]), end='')
print(" ")
#обработка
j=0
for i in range(l):
    if a[i]!=0:
        a[j]=a[i]
        j=j+1
for i in range(j, l):
    a[i]=0
#вывод на экран обработанного массива
for i in range(l):
    print("%3d" % (a[i]), end='')
или так
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
#python 3.6.9
 
a = [4, 0, 5, 0, 3, 0, 0, 5]
l=8
#вывод на экран исходного массива
for i in range(l):
    print("%3d" % (a[i]), end='')
print(" ")
#обработка:
# - поиск первого нулевого - начальной позиции для изменений
j=l+1
for i in range(l):
    if a[i]==0:
        j=i
        break
# - копирование ненулевых элементов в начало массива
for i in range(j, l):
    if a[i]!=0:
        a[j]=a[i]
        a[i]=0
        j=j+1
#вывод на экран обработанного массива
for i in range(l):
    print("%3d" % (a[i]), end='')
Этот вариант длиннее по исходнику, но явно проще по числу действий.

Или скриптовый Python быстрее обработает однострочную функцию, чем многострочный циклический алгоритм? Т.е. существуют особенности реализации языка?

Добавлено через 3 минуты
Пока изучал язык, подобные решения тоже привели...
1
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 13:22
ФедосеевПавел,

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
30
import random as unicorn
 
@benchmark(spent=True, amount=1)
def func_Pavel_1(a, l):
    #вывод на экран исходного массива
    j=0
    for i in range(l):
        if a[i]!=0:
            a[j]=a[i]
            j=j+1
    for i in range(j, l):
        a[i]=0
 
 
@benchmark(spent=True, amount=1)
def func_vic5710(a, l):
    a.sort(key=lambda x: not x)
 
@benchmark(spent=True, amount=1)
def func_DmFat(a, l):
    sorted(a, key=lambda x: not x)
 
a = [unicorn.randint(0, 10) for i in range(100000)]
func_Pavel_1(a, len(a))
func_vic5710(a, len(a))
func_DmFat(a, len(a))
 
# function: func_Pavel_1 spent time - 0.018237207000 usec
# function: func_vic5710 spent time - 0.009050607000 usec
# function: func_DmFat   spent time - 0.008948612000 usec
Добавлено через 14 минут
Более правильный пример:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@benchmark(spent=True, amount=1)
def func_1(n):
    return [i * j for i in range(n) for j in range(n)]
 
 
@benchmark(spent=True, amount=1)
def func_2(n):
    a = []
    for i in range(n):
        for j in range(n):
            a.append(i * j)
 
 
func_1(1000)
func_2(1000)
 
# function: func_1 spent time - 0.088062359000 usec
# function: func_2 spent time - 0.134106015000 usec
1
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8652 / 4487 / 1669
Регистрация: 01.02.2015
Сообщений: 13,894
Записей в блоге: 12
06.08.2020, 14:30
Не разобрался, как в онлайн-компиляторе подключить @benchmark и StressTestsTools
Поэтому воспользовался
https://stackoverflow.com/ques... hon-script
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import random as unicorn
 
def timereps(reps, func):
    from time import time
    start = time()
    for i in range(0, reps):
        func()
    end = time()
    return (end - start) / reps
 
def func_Pavel_1(a, l):
    j=0
    for i in range(l):
        if a[i]!=0:
            a[j]=a[i]
            j=j+1
    for i in range(j, l):
        a[i]=0
 
def func_Pavel_2(a, l):
    j=l+1
    for i in range(l):
        if a[i]==0:
            j=i
            break
# - копирование ненулевых элементов в начало массива
    for i in range(j, l):
        if a[i]!=0:
            a[j]=a[i]
            a[i]=0
            j=j+1
 
def func_vic5710(a, l):
    a.sort(key=lambda x: not x)
 
def func_DmFat(a, l):
    sorted(a, key=lambda x: not x)
 
a = [unicorn.randint(0, 10) for i in range(100000)]
 
#func_Pavel_1(a, len(a))
listdir_time = timereps(10, lambda: func_Pavel_1(a, len(a)))
print( "python can do %d func_Pavel_1(a, len(a)) per second" % (1 / listdir_time))
 
#func_Pavel_2(a, len(a))
listdir_time = timereps(10, lambda: func_Pavel_2(a, len(a)))
print( "python can do %d func_Pavel_2(a, len(a)) per second" % (1 / listdir_time))
 
#func_vic5710(a, len(a))
listdir_time = timereps(10, lambda: func_vic5710(a, len(a)))
print( "python can do %d func_vic5710(a, len(a)) per second" % (1 / listdir_time))
 
#func_DmFat(a, len(a))
listdir_time = timereps(10, lambda: func_vic5710(a, len(a)))
print( "python can do %d func_vic5710(a, len(a)) per second" % (1 / listdir_time))
В онлайн-компиляторе
https://rextester.com/l/python3_online_compiler
результаты меняются и не могу увеличить количество тестов - система "убивает" процесс.
Но результаты не столь удручающи
Code
1
2
3
4
python can do 66 func_Pavel_1(a, len(a)) per second
python can do 128 func_Pavel_2(a, len(a)) per second
python can do 84 func_vic5710(a, len(a)) per second
python can do 93 func_vic5710(a, len(a)) per second
Code
1
2
3
4
python can do 94 func_Pavel_1(a, len(a)) per second
python can do 217 func_Pavel_2(a, len(a)) per second
python can do 105 func_vic5710(a, len(a)) per second
python can do 106 func_vic5710(a, len(a)) per second
Code
1
2
3
4
python can do 56 func_Pavel_1(a, len(a)) per second
python can do 127 func_Pavel_2(a, len(a)) per second
python can do 87 func_vic5710(a, len(a)) per second
python can do 103 func_vic5710(a, len(a)) per second
Видимо, это особенность интерпретатора - время исполнения сильно нивелируется и слабо зависит от алгоритма.
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 15:36
ФедосеевПавел, не получилось, потому что это мои личные модули, извиняюсь что не указал этого.

Тут дела вкуса, для меня проще когда кода меньше. Кому то наоборот, надо сильнее разжевывать код для понимания.

Например создание двумерного массива заполненного нулями, красивее и более понятно выглядит, вот так:
Python
1
matrix = [[0 for _ in range(n)] for _ in range(n)]
чем вот так:
Python
1
2
3
4
5
matrix = []
for i in range(n):
    matrix.append([])
    for j in range(n):
        matrix[i].append(0)
Добавлено через 3 минуты
Еще пример:
Python
1
2
collection = [1, 0, 2, 0, 3, 0, 4]
print(*[element for element in collection if element != 0])
Python
1
2
3
4
5
collection = [1, 0, 2, 0, 3, 0, 4]
for element in collection:
    if element != 0:
        print(element, end=" ")
print()
1
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
06.08.2020, 15:52
DmFat, но согласитесь, что длинный код вида
Цитата Сообщение от DmFat Посмотреть сообщение
print(*collection if (collection := input().split()).sort(key=lambda x: not int(x)) is None else None)
сложнее для понимания (имхо)
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
06.08.2020, 16:18
ioprst, Естественно это код был написан просто ради смеха.
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
06.08.2020, 16:40
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
решения с выделениями дополнительной памяти, сортировкой
Сортировка inplace доп. память не выделяет.
По моим тестам ваш вариант в 1.5 раза медленнее встроенной сортировки на 100_000 списке.
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8652 / 4487 / 1669
Регистрация: 01.02.2015
Сообщений: 13,894
Записей в блоге: 12
06.08.2020, 16:45
Который вариант - первый или второй?
Второй - в общем-то быстрее тех алгоритмов, что сравнивались в сообщении 33
Python
1
2
3
4
5
6
7
8
9
10
11
12
def func_Pavel_2(a, l):
    j=l+1
    for i in range(l):
        if a[i]==0:
            j=i
            break
# - копирование ненулевых элементов в начало массива
    for i in range(j, l):
        if a[i]!=0:
            a[j]=a[i]
            a[i]=0
            j=j+1
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
06.08.2020, 16:49
Цитата Сообщение от ФедосеевПавел Посмотреть сообщение
первый или второй?
Второй вариант практически ничем не отличается по производительности. Скажем, если первый на моем компе выполнялся 33 ms, второй 31 ms. Вариант со встроенной inplace сортировкой за 20ms.
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8652 / 4487 / 1669
Регистрация: 01.02.2015
Сообщений: 13,894
Записей в блоге: 12
06.08.2020, 16:51
А если такой такой разброс в скорости - 1,5 раза - то чем объяснить?
Ведь в моём коде нет лишних операций - поиск первого нуля и дальнейший перенос ненулевых элементов. В разных условиях может оказаться, что заполнение нулями не в цикле, а в конце отдельной строкой будет быстрее.
Но при сортировке такой оптимальности не будет - будет обмен значениями.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.08.2020, 16:51
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
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
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru