Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/25: Рейтинг темы: голосов - 25, средняя оценка - 4.72
 Аватар для Ivan _pupkin
3 / 3 / 1
Регистрация: 17.12.2018
Сообщений: 257

Удалить строку матрицы, в которой количество нулей максимально

22.01.2019, 19:34. Показов 4785. Ответов 3

Студворк — интернет-сервис помощи студентам
Я решил эту задачу как решал на с++. Хочу знать, можно ли решить её как-то по проще, чтобы код не выглядел таким громоздким?
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
rows = int(input("Укажите кол-во срок: "))
cols = int(input("Укажите кол-во столбцов: "))
arr = [[random.randint(0, 9) for i in range(cols)] for n in range(rows)]
counter_zeros_arr = [random.randint(-5, -1) for _ in range(rows)]
 
for i in range(rows):
    for j in range(cols):
        print(arr[i][j], end='\t')
    print()
 
for i in range(rows):
    counter_zeros = 0
    lol = 0
    for j in range(cols):
        if arr[i][j] == 0:
            counter_zeros += 1
            lol = 1
    if lol == 1:
        counter_zeros_arr[i] = counter_zeros
 
index_max_zeros = -1
for i in range(rows):
    if index_max_zeros < counter_zeros_arr[i]:
        index_max_zeros = i
 
if index_max_zeros >= 0:
    print("Строка с максимальным кол-ом нулей:", index_max_zeros)
    lol = 0
    for i in range(rows):
        if lol == 1:
            break
        for j in range(cols):
            if i == index_max_zeros:
                if i == rows - 1:
                    rows -= 1
                    break
                for k in range(i, rows - 1):
                    for q in range(cols):
                        arr[k][q] = arr[k + 1][q]
                rows -= 1
                lol = 1
                break
            else:
                break
 
    print("\nИзменённая матрица")
    for i in range(rows):
        for j in range(cols):
            print(arr[i][j], end='\t')
        print()
else:
    print("В матрице нету нулей")
И ещё, можно ли в питоне копировать старый, изменённый массив в новый и удалить его, как в с++ с динамическими?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.01.2019, 19:34
Ответы с готовыми решениями:

Удалить строку матрицы, в которой количество нулей максимально
Программа вроде бы работает, но я не понимаю что происходит начиная со строки 41.( Половину кода писала сама, а часть, где определяется...

Удалить строку матрицы, в которой количество нулей максимально
Удалить строку матрицы, в которой количество нулей максимально. Помогите пожалуйста! Без функций, максимально просто!

В матрицу вставить строку из нулей после первой из строки, количество нулей в которой равно m
Помогите пожалуйста! дан двумерный массив.вставить в него строку из нулей после первой из строк.количество нулей которых равно m паскаль

3
338 / 127 / 114
Регистрация: 09.04.2011
Сообщений: 246
22.01.2019, 21:21
Можно так например

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
from random import randint
rows = int(input("Укажите кол-во строк: "))
cols = int(input("Укажите кол-во столбцов: "))
arr = [[randint(0, 1) for i in range(cols)] for n in range(rows)]
tmp = 0
 
def matrix(arr):
    for i in arr:
        for el in i:
            print(el, end=' ')
        print()
        
matrix(arr)
print("\n")
 
for i in range(rows):
    count = 0
    for j in range(cols):
        if not arr[i][j]:
            count += 1
    if count >= tmp:
        tmp = count
        pos = i
 
if count:
    del arr[pos] #Если 2 строки с одинаковым кол-вом нулей, то удаляет последнюю из них
    matrix(arr) 
    
else:
    print("В матрице нету нулей")
Цитата Сообщение от Ivan _pupkin Посмотреть сообщение
И ещё, можно ли в питоне копировать старый, изменённый массив в новый и удалить его, как в с++ с динамическими?
Тут не совсем понял, да и не было опыта с C++, так что не в курсе
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
22.01.2019, 21:30
Нда, даже в С++ так в общем-то не делают...
Решение в две строки:
Python
1
2
3
seq = [row.count(0) for row in arr] # список всех частот нулей в каждой строке 2D списка
>>> del arr[seq.index(max(seq))] # это  argmax - индекс маскимального значения
>> # del это удаление
0
 Аватар для Ivan _pupkin
3 / 3 / 1
Регистрация: 17.12.2018
Сообщений: 257
23.01.2019, 02:04  [ТС]
Garry Galler, а как делают на с++ ?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.01.2019, 02:04
Помогаю со студенческими работами здесь

Вставить в матрицу строку из нулей после первой из строк, количество нулей в которой равно заданному числу
Дан двумерный массив. Вставить в него строку из нулей после первой из строк, количество нулей в которой равно заданному числу. Вот...

Вставить в матрицу строку из нулей после первой из строк, количество нулей в которой равно заданному числу
Дан двумерный массив. Вставить в него строку из нулей после первой из строк, количество нулей в которой равно заданному числу.

Найти строку в которой количество положительных элементов максимально
Подскажите. как можно найти строку в которой количество положительных элементов максимально? Ломаю голову, не знаю как быстро и просто...

Найти строку матрицы, для которой произведение нулевого диагонального элементов максимально
Дана матрица А . Найти строку матрицы, для которой произведение нулевого н диагонального элементов максимально. Отсортировать заданный...

Найти строку матрицы в которой больше всего нулей(исправить код программы).
Найти строку матрицы в которой больше всего нулей. Вот, что у меня получилось: const n=5; type sqmatr=array of integer; procedure...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты 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. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru