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

Графы

07.12.2020, 07:58. Показов 3141. Ответов 1

Студворк — интернет-сервис помощи студентам
Задание 4. Задан граф в виде количества вершин n<=7, количества ребер k<=28 и матрицы инцидентности. а) Для каждой вершины напечатать список инцидентных ей ребер. б) Определить степень каждой вершины графа. в) Проверить, есть ли вершины со степенью 0. г) Определить число вершин, инцидентных только одному ребру. д) Определить наибольшее число смежных между собой ребер, инцидентных одной и той же вершине. е) Проверить, есть ли в графе петли

не могу понять как перевести код на другую строку чтобы там тоже продолжался проверка на инцидентность матрицы:
Сама матрица:
[1 1 0 0 0 0]
[1 0 1 0 0 0]
[0 1 1 1 0 0]
[0 0 0 1 0 0]
[0 0 0 0 0 0]
[0 0 0 0 1 1]
[0 0 0 0 1 0]


Мой код:
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
def graph(l, q):
    for i in range(n):
        if matrix[l][q] == 1:
            inc.append((matrix[l][q]))
            print("Данное ребро инцидентно  вершине a")
        if matrix [l][q] != 1:
            print('Данное ребро не инцидентно этой вершине')
        return inc
 
 
def graph1(l, q):
    for z in range(n * k):
        if q <= 6:
            print(graph(l, q))
            q += 1
            z += 1
        else:
            l += 1
            q = 0
            z += 1
 
 
n = int(input("Введите кол-во вершин: "))
k = int(input("Введите кол-во ребер: "))
inc = []
z = 0
 
 
if (n > 0) and (n <= 7) and (k <= 27) and (k > 0):
    matrix = [[0] * n] * k
    for i in range(len(matrix)):
        string = input("введите матрицу: ")
        line = string.split()
        line = [int(x) for x in line]
        matrix[i] = line
        i += 1
d = [[matrix for y in range(n)] for x in range(k)]
for im in range(k):
    print(matrix[im])
 
"""for z in range(n*k):
    if s <= 4:
        print(graph(m, s))
        s += 1
        z += 1
    else:
        m += 1
        s = 0
        z += 1
"""
print(graph1(0,0))
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.12.2020, 07:58
Ответы с готовыми решениями:

Графы
Помогите разобраться. Я строю граф с помощью библиотеки networkx import networkx as nx import matplotlib.pyplot as plt G =...

Графы
Помогите решить. Я смог решить на С++ но не знаю как решить на python ибо плохо его знаю В подземелье m тоннелей и n перекрестков,...

Графы
Здравствуйте! Во время изучения пайтона я столкнулся с такой структурой как граф. Теория графов мне более-менее понятна. Но вот...

1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 14
07.12.2020, 11:09
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
def task(matr):
    n=len(matr) # число вершин
    k=len(matr[0]) # число ребер
    #а)
    print("\nа)\n")
    for v in range(n):
        for e in range(k):
            if matr[v][e] != 0:
                print("Вершине ",v,"инцидентно ребрo",e)
    #б)
    print("\nб)\n")
    for a,p in enumerate(list(map(sum,matr))):
        print("Степень вершины",a,"=",p)
 
    #в)
    print("\nв)\n")
    for a,p in enumerate(list(map(sum,matr))):
        if p==0:
            print("Степень вершины",a,"=",p)
 
    #г)
    print("\nг)\n")
    c=0
    for r in matr:
        if sum(r)==1:
            c+=1
    print("Число вершин, инцидентных одному ребру=",c)        
 
    #д)
    print("\nд)\n")
    c=max(map(sum,matr))
    print("Наибольшее число смежных между собой ребер=",c)        
 
    #е)
    print("\nе)\n")
    l=0
    for e in range(k):
        s=0
        for v in range(n):
            s+=matr[v][e]
        if s==1:
            print("Ребро",v,"-петля")
            l+=1
    if l==0:
        print("В графе петель нет")
 
m=[[1,1,0,0,0,0],
   [1,0,1,0,0,0],
   [0,1,1,1,0,0],
   [0,0,0,1,0,0],
   [0,0,0,0,0,0],
   [0,0,0,0,1,1],
   [0,0,0,0,1,0]]
  
task(m)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.12.2020, 11:09
Помогаю со студенческими работами здесь

Задача на графы
Страна замов - это место, где каждый человек (кроме директора) работает чьим-то заместителем, причем его должность - это должность его...

Статистика и графы
Только начинаю изучать Python и графы, пытаюсь найти оптимальное решение такой задачи: Нужно найти и хранить статистику по часто...

Графы пайтон задачка
В галактике Milky Way на планете Neptune есть n городов, некоторые из которых соединены дорогами. Император &quot;Maximus&quot; галактики...

Обход в ширину (графы)
Нужно решить следующую задачу на Python: В неориентированном графе требуется найти длину кратчайшего пути между двумя вершинами. ...

Графы. Количество отдельных государств на карте острова
На острове расположены несколько государств, изолированных друг от друга. У программиста Васи есть данные обо всех дорогах острова,...


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

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