Преобразования описаний графа
Тема 4. ГРАФЫ И СЕТИ
Способы задания графов
Теория.
1. Графическим изображением.
2. Множеством вершин и дуг: совокупностью двух множеств — непустого множества V (множества вершин) и множества Е неупорядоченных пар различных элементов множества V (Е — множество ребер)
3. Матрицей инцидентности
размера
: по вертикали и горизонтали указываются вершины и ребра соответственно, а на пересечении i-й вершины и j-го ребра в случае неориентированного графа записывается 1, если они инцидентны, и 0 – в противном случае, т.е.

В случае орграфа на пересечении i-й вершины и j-го ребра записывается минус единица (-1), если вершина является началом ребра и единица (+1) если вершина является концом ребра; 0 – записывается, если вершина и ребро не инцидентны. Если некоторая вершина является для ребра и началом, и концом (т.е. ребро – петля), проставляется любое другое число, например 2, т.е.

где
любое число, отличное от -1, 1. 0.
4. Списком ребер графа, представленным двумя столбцами: в левом перечисляются все ребра
, а в правом – инцидентные ему вершины vij. Для н-графа порядок вершин в строке произволен, для орграфа первым стоит номер начала ребра;
5. Матрицей смежности
–квадратной матрицей размера
, гдепо вертикали и горизонтали перечисляются все вершины
,а на пересечении k-й и l-й вершин в случае н-графа проставляется число, равное числу ребер, соединяющих эти вершины. Для орграфа
равно числу ребер с началом в k-й вершине и концом в l-й.
Пример 1. Задать сетевой граф, изображенный на рис. 1 различными способами.

Рис 1.
Решение:
1. Графическое задание представлено на рисунке.
2. Множеством вершин и дуг:
V={1,2,3,4,5,6}, E={(1,2),(1,3),(2,4),(2,5),(3,4),(4,6),(5,6)}.
3. Матрицей инцидентности:
Таблица 1
| G | a | b | c | d | e | f | g |
| -1 | -1 | ||||||
| -1 | -1 | ||||||
| -1 | |||||||
| -1 | |||||||
| -1 | |||||||
4. Матрицей смежности:
Таблица 2
| G | ||||||
5. Списком ребер:
Таблица 3
| Ребро | Вершины |
| a | 1,2 |
| b | 1,3 |
| c | 3,4 |
| d | 2,4 |
| e | 2,5 |
| f | 5,6 |
| g | 4,6 |
Пример 2. Построить графическое изображение графа заданного матрицей инцидентности вида:
Таблица 4
| G | I | II | III | IV | V | VI | VII |
Решение.
При наличии матрицы инцидентности число всех вершин и число ребер графа определяется очевидным образом по размеру матрицы: число ребер графа |E| равно числу строк m, а число вершин |V| – числу столбцов n матрицы. В данном примере m=11, n=7.
Граф выглядит следующим образом:

Рис. 2
Пример 3. Построить графическое изображение орграфа заданного матрицей смежности вида:
Таблица 5
| G | I | II | III | IV | V | VI | VII |
| I | |||||||
| II | |||||||
| III | |||||||
| IV | |||||||
| V | |||||||
| VI | |||||||
| VII |
Решение.
По матрице смежности определим число вершин графа определяется порядком n матрицы. В данном примере n=7. Число ребер орграфа определяется всеми элементами
матрицы смежности. Отсюда их число равно:
=10.
Граф выглядит следующим образом:

Рис. 3
Пример 4. Построить графическое изображение двух графов G1 и G2 заданных списками своих ребер вида:
Таблица 6 Таблица 7
| G1 | G2 | |||
| Ребро | Вершины | Ребро | Вершины | |
| a | 1,2 | a | 1,2 | |
| b | 2,2 | b | 2,3 | |
| c | 2,3 | c | 3,4 | |
| d | 3,3 | d | 4,5 | |
| e | 3,5 | e | 1,1 | |
| f | 1,4 | f | 1,5 | |
| g | 4,5 | g | 5,5 |
Решение.
Количество вершин равно 5, количество ребер равно 7. Графы выглядят следующим образом:

Рис. 4 Рис. 5
Преобразования описаний графа
Теория.
Построение матрицы инцидентности по списку ребер. Каждая строка списка соответствует строке матрицы с тем же номером. Для н-графа в строке списка указаны номера элементов строки матрицы инцидентности, равные 1. Для орграфа в этой строке первым стоит номер элемента строки матрицы, равного -1, а вторым – номер элемента, равного 1. При совпадении номеров в строке списка ребер в названном элементе строки матрицы инцидентности проставляется, например, 2.
Построение по матрице смежности списка ребер. Элементу матрицы, расположенному в i-й строке и j-ом столбце, соответствует
строк списка ребер (при
= 0 – ни одной строки), в каждой из которых записаны номера i, j. Для н-графа эти строки соответствуют только элементам верхнего правого треугольника матрицы смежности, т.е. элементам
, а для орграфа нужно рассматривать все элементы
.
Матрица смежности н-графа симметрична относительно главной диагонали
, и все его ребра определяются верхним правым треугольником матрицы, расположенным над диагональю, включая последнюю. Таким образом, число ребер н-графа по матрице смежности равно сумме элементов
, расположенных на диагонали и выше, т.е. равно:
.
Ребра орграфа определяются всеми элементами
матрицы смежности, отсюда их число равно:

Список ребер графа является, по существу, сокращенным представлением матрицы инцидентности (в каждой ее строке только два элемента отличны от 0 или даже один, если ребро – петля).
Пример 5. Построить матрицу инцидентности н-графа по списку ребер вида:
Таблица 8
| Ребро | Вершины |
| A,B | |
| A,C | |
| B,D | |
| A,E | |
| C,D | |
| C,D | |
| D,D | |
| C,E | |
| D,G | |
| E,F | |
| F,G |
Решение.
Количество вершин равно 7, количество ребер равно 11. Таким образом, матрица инцидентности будет иметь 7 столбцов и 11 строк.
Таблица 9
| G | A | B | C | D | E | F | G |
Матрица инцидентности (таблица 9) совпадает с таблицей инцидентности (таблица 4) и граф, описанный данной таблицей, может иметь вид рис. 2.
Пример 6. Построить список ребер графа по матрице смежности вида:
Таблица 10
| G | |||||
Решение.
Количество вершин графа равно числу строк и столбцов матрицы и равно 5, а количество ребер вычисляется по формуле
=7.
Обозначим ребра буквами латинского алфавита. Тогда список ребер графа будет имеет следующий вид:
Таблица 11
| G1 | |
| Ребро | Вершины |
| a | 1,2 |
| b | 2,2 |
| c | 2,3 |
| d | 3,3 |
| e | 3,5 |
| f | 1,4 |
| g | 4,5 |
Данная таблица соответствует списку ребер (таблица 6) графа изображенного на рис. 4.