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

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

26.07.2018, 00:20. Показов 50169. Ответов 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
 Аватар для Fudthhh
2696 / 1602 / 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
2696 / 1602 / 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
2696 / 1602 / 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
2696 / 1602 / 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
38204 / 21136 / 4310
Регистрация: 12.02.2012
Сообщений: 34,748
Записей в блоге: 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
2696 / 1602 / 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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8667 / 4504 / 1670
Регистрация: 01.02.2015
Сообщений: 13,934
Записей в блоге: 13
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
2696 / 1602 / 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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8667 / 4504 / 1670
Регистрация: 01.02.2015
Сообщений: 13,934
Записей в блоге: 13
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
2696 / 1602 / 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
2696 / 1602 / 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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8667 / 4504 / 1670
Регистрация: 01.02.2015
Сообщений: 13,934
Записей в блоге: 13
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
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8667 / 4504 / 1670
Регистрация: 01.02.2015
Сообщений: 13,934
Записей в блоге: 13
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
Ответ Создать тему
Новые блоги и статьи
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера» Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит. Придуман Биллом Госпером в 1970-х, опубликован в. . .
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb"> <style> <!]> </ style> <g id="bush"> </ g> </ svg> function fn(){ let rost;/ / высота древа let xx=165,yy=210,w=256;
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru