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

Задача на двумерные списки

13.09.2017, 11:31. Показов 8635. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребят, нужна помощь. Есть задача:

'Выполнить обработку элементов прямоугольной матрицы A, имеющей N строк и M столбцов. Все элементы имеют целый тип. Дано целое число H. Определить, какие столбцы имеют хотя бы одно такое число, а какие не имеют.'

Я уже написал немного:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
from random import randint
 
number_of_colomn = int(input('Введите N: '))
number_of_row = int(input('Введите M: '))
H = int(input('Введите H: '))
my_array = []
for i in range(number_of_colomn):
    temp=[]
    for j in range(number_of_row):
        n = randint(0,10) 
        temp.append(n)
    my_array.append(temp)
print(my_array)
Есть два вопроса:

1) как красиво вывести матрицу;

2) Как собственно определить, какие столбцы имеют хотя бы одно такое число. Помогите, я новичок
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.09.2017, 11:31
Ответы с готовыми решениями:

Двумерные списки
1. Задана квадратная матрица. Переставить строку с максимальным элементом на главной диагонали со строкой с заданным номером m. ...

Непонятки про двумерные списки
Допустим у нас есть двумерный список a = ,,] можем мы ли как как-то столбы сделать строками и наоборот Т.е из того что я написал должно...

Двумерные списки в Python, не могу разобраться
Здравствуйте! Здравствуйте! Столкнулась с тем, что не получается создать двумерный массив, записывая данные из файла. Дан файл...

7
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
13.09.2017, 12:05
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
m = [
    [1, 2, 7], 
    [5, 4, 5],
    [5, 6, 8]
    ]
n = 5
 
for num,column in enumerate(zip(*m)):
    if n in column:
        indices = [idx for idx,_ in enumerate(column) if _==n]
        print('The column {} contains {} by index {}'.format(num,n,indices))
    else:
        print('The column {} does not contain {}'.format(num,n))
0
 Аватар для Semen-Semenich
5222 / 3469 / 1173
Регистрация: 21.03.2016
Сообщений: 8,295
13.09.2017, 12:08
Python
1
2
3
4
5
6
7
8
9
10
from random import randint
 
n = int(input('Введите N: '))
m = int(input('Введите M: '))
h = int(input('Введите H: '))
my_array = [[randint(0,10) for _ in range (m)] for _ in range (n)]
for i in range(m):
  for j in range(n):
    if my_array [j][i] == h:
      print('столбец{} имеет цифру {}'.format(i,h))
единственное что будет выводить результат на каждое совпадение в столбике. для этого можно результат добавлять в множество а уже из него делать вывод
0
0 / 0 / 0
Регистрация: 13.09.2017
Сообщений: 26
13.09.2017, 18:37  [ТС]
Python
1
my_array = [[randint(0,10) for _ in range (m)] for _ in range (n)]
А можете пожалуйста объяснить эту строчку, а то не совсем понимаю как работает
0
 Аватар для Semen-Semenich
5222 / 3469 / 1173
Регистрация: 21.03.2016
Сообщений: 8,295
13.09.2017, 19:33
Python
1
my_array = [[randint(0,10) for _ in range (m)] for _ in range (n)]
простой принцип в одной строке- генератор списка
Python
1
2
3
4
5
6
my_array = [] # основной список (м)ассив)
for _ in range(n):
   x = [] # при каждом проходе заводим пустой список
   for i in range(m):
       x.append(randint(0,10)) # добавляем в спиок х  m рандомов
  my_array.append(x) # добавляем список x  в основной список и так n раз
в результате получаем список из n элементов где каждый хлемент это список из m элементов то есть получили матрицу
0
0 / 0 / 0
Регистрация: 13.09.2017
Сообщений: 26
13.09.2017, 19:41  [ТС]
То есть генератор списков - это упрощенный способ создания списка?
0
 Аватар для Semen-Semenich
5222 / 3469 / 1173
Регистрация: 21.03.2016
Сообщений: 8,295
13.09.2017, 20:08
http://younglinux.info/python/feature/generators
http://pythontutor.ru/lessons/2d_arrays/
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5972 / 3734 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
14.09.2017, 17:12
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#!/usr/bin/env python3
import numpy as np
 
#~ n = int(input('Введите N: '))
#~ m = int(input('Введите M: '))
#~ h = int(input('Введите H: '))
 
n, m, h = 3, 5, 5
 
a = np.random.randint(10, size=(n, m))
print(a)
 
for i in range(a.shape[1]):
    if h in a[:,i]:
        print(i)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.09.2017, 17:12
Помогаю со студенческими работами здесь

Двумерные списки. Простой поиск
Помогите пожалуйста написать код по этой задаче

Тема Двумерные списки. Простой поиск
Создать массив с элементами akn=n f ( k ) + sin ( k ) g (n), где k, n =1, 2, 3, 4; f(k)=11,2cos(2k-1)+|sin1,5k|/1,7 g(n)=9,2cos...

Двумерные списки: определить индексы минимального и максимального элементов
Задание:Смотрите прикреплённое фото --------------------------------------------------------------------------------------------------- ...

Двумерные списки
Создать список с элементами

Двумерные Списки Python3
Помогите написать код Задание:https://www.cyberforum.ru/attachment.php?attachmentid=1102163&stc=1&d=1578485955


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
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