Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Методичка по лаб ТОИ.doc
Скачиваний:
17
Добавлен:
10.11.2019
Размер:
3.67 Mб
Скачать
  1. Список литературы

  1. Пильщиков В.Н., Абрамов В.Г., Вылиток А.А., Горячая И.В. Машина Тьюринга и алгоритмы Маркова. Решение задач. (Учебно-методическое пособие) - М.: МГУ, 2006. – 47 с.

  2. Пономарев В.Ф. Дискретная математика для инженеров.- Калининград: ФГОУ ВПО КГТУ, 2010.- 351 с.

Расчетно-графическая работа №6 Тема: «Расчет числовых характеристик графов».

  1. Теоретическая часть

Пусть задан граф G (рисунок 6.1).

Р исунок 6.1 ― Граф G

Расчет количества вершин n(G) графа G

Расчет выполняется методом визуального анализа графа G. В итоге расчета имеем:

Расчет количества ребер m(G) графа G

Расчет выполняется методом визуального анализа графа G. В итоге расчета имеем:

Расчет степеней вершин δi графа G.

Расчет выполняется методом визуального анализа графа G с целью определения количества ребер (дуг) инцидентных вершине xi. Результаты расчета сведены в таблицу 6.1.

Таблица 6.1 - Результаты расчета степеней вершин графа G

xi

δi

1

2

2

2

3

2

4

2

5

3

6

2

7

5

8

2

9

2

Расчет числа компонент связности æ(G)

Д

ля расчета числа компонент связности графа G вычисляют матрицу достижимости ||Qp|| и определяют полные подграфы графа. Для построения матрицы достижимости удобно воспользоваться матрицей смежности графа G:

где ||1|| - единичная матрица (рисунок 6.2),

||H(xi)|| - матрица смежности графа G,

||Hp(xi)|| - матрица смежности графа G, возведенная в p-ую степень.

1

1

2

3

4

5

6

7

8

9

1

1

0

0

0

0

0

0

0

0

2

0

1

0

0

0

0

0

0

0

3

0

0

1

0

0

0

0

0

0

4

0

0

0

1

0

0

0

0

0

5

0

0

0

0

1

0

0

0

0

6

0

0

0

0

0

1

0

0

0

7

0

0

0

0

0

0

1

0

0

8

0

0

0

0

0

0

0

1

0

9

0

0

0

0

0

0

0

0

1

Рисунок 6.2 ― Единичная матрица для графа G

Для возведения в степень матрицы смежности используют правило умножения булевых матриц.

На рисунке 6.3 правило умножения булевых матриц прокомментировано графически.

Первая строка на второй столбец

Обозначения: - дизъюнкция (см. таблицу истинности в [1] ); - конъюнкция (см. таблицу истинности в [1])

Рисунок 6.3 ― Пример умножения булевых матриц 4х4

Построим матрицы смежности графа G (рисунок 6.4).

H

1

2

3

4

5

6

7

8

9

1

0

1

1

0

0

0

0

0

0

2

1

0

1

0

0

0

0

0

0

3

1

1

0

0

0

0

0

0

0

4

0

0

0

0

1

0

1

0

0

5

0

0

0

1

0

1

1

0

0

6

0

0

0

0

1

0

1

0

0

7

0

0

0

1

1

1

0

1

1

8

0

0

0

0

0

0

1

0

1

9

0

0

0

0

0

0

1

1

0


Рисунок 6.4 ― Матрица смежности ||H|| графа G

Возведем матрицу смежности ||H|| в квадрат, т.е. умножим ее саму на себя. Получим ||H2|| (рисунок 6.5).

H2

1

2

3

4

5

6

7

8

9

1

1

1

1

0

0

0

0

0

0

2

1

1

1

0

0

0

0

0

0

3

1

1

1

0

0

0

0

0

0

4

0

0

0

1

1

1

1

1

1

5

0

0

0

1

1

1

1

1

1

6

0

0

0

1

1

1

1

1

1

7

0

0

0

1

1

1

1

1

1

8

0

0

0

1

1

1

1

1

1

9

0

0

0

1

1

1

1

1

1

Рисунок 6.5 ― Матрица ||H2|| графа G

Возведем матрицу смежности ||H|| в третью степень. Получим ||H3|| (рисунок 6.6).

H3

1

2

3

4

5

6

7

8

9

1

1

1

1

0

0

0

0

0

0

2

1

1

1

0

0

0

0

0

0

3

1

1

1

0

0

0

0

0

0

4

0

0

0

1

1

1

1

1

1

5

0

0

0

1

1

1

1

1

1

6

0

0

0

1

1

1

1

1

1

7

0

0

0

1

1

1

1

1

1

8

0

0

0

1

1

1

1

1

1

9

0

0

0

1

1

1

1

1

1

Рисунок 6.6 ― Матрица ||H3|| графа G

Анализ матриц ||H2|| и ||H3|| показывает, что никаких изменений в ||H3|| по сравнению ||H2|| нет. Значит процесс вычислений завершен.

Матрица достижимости ||Q3|| (рисунок 6.7) рассчитывается следующим образом:

Q2

1

2

3

4

5

6

7

8

9

1

1

1

1

0

0

0

0

0

0

2

1

1

1

0

0

0

0

0

0

3

1

1

1

0

0

0

0

0

0

4

0

0

0

1

1

1

1

1

1

5

0

0

0

1

1

1

1

1

1

6

0

0

0

1

1

1

1

1

1

7

0

0

0

1

1

1

1

1

1

8

0

0

0

1

1

1

1

1

1

9

0

0

0

1

1

1

1

1

1

Рисунок 6.7 ― Матрица ||Q2|| графа G

Поскольку матрица ||Q2|| содержит два блока: один – 3х3 элемента, другой – 6х6 элементов, то граф G содержит два связных подграфа:

G1=<X1, H1>, G2=<X2, H2>,

где X1={x1,x2,x3}, X2={x4,x5,x6,x7,x8,x9}.

Таким образом, для исходного графа G=<X,H> число компонент связности равно æ(G)=2.

Расчет цикломатического числа λ(G) графа G

Рассчитаем цикломатическое число графа G, т.е. наименьшее число ребер, удаление которых приведет к графу без циклов и петель.

Расчет выполним по формуле:

.

В качестве примера удалим на графе G четыре ребра (1,3), (4,5), (5,6), (8,9). Получим граф на рисунке 6.8.

Р исунок 6.8 ― Граф без циклов и петель

Расчет хроматического числа γ(G) графа G

Рассчитаем хроматическое число графа G, т.е. наименьшее число красок при применении которых для раскраски вершин графа две любые смежные вершины графа G, не будут окрашены в один цвет.

Для выполнения расчета воспользуемся двумя оценочными соотношениями. Одно из них задает левую границу для γ(G), min возможное значение γ(G), т.е. γmin(G):

  1. полный n-вершинный граф имеет γmin(G)=n;

  2. пустой граф имеет γmin(G)=1;

  3. граф с циклом (т.е. хотя бы одним) четной длины имеет γmin(G)=2;

  4. граф с циклом нечетной длины имеет γmin(G)=3;

  5. граф-дерево имеет γmin(G)=2.

Другое оценочное соотношение задает правую границу для γ(G), max необходимое значение γ(G), т.е. γmax(G):

.

Начинаем проверку с вычисления γmin(G). Поскольку в графе G есть цикл нечетной длины пробуем раскрасить граф тремя красками (рисунок 6.9).

Рисунок 6.9 ― Раскраска графа G синей, желтой и красной красками

Вывод: трех красок, т.е. γmin(G)=3 оказалось достаточно:

.

Если бы трех красок оказалось недостаточно, следовало бы γmin(G) увеличить на единицу и повторить раскраску заново. И так далее, до получения желаемого результата. Однако таких красок не должно быть больше чем γmax(G).

Расчет плотности (G) графа G

Рассчитаем плотность графа G, т.е. наибольшее число вершин подграфа графа G, между всеми вершинами которого задано отношение смежности.

Получим матрицы смежности ||H|| и достижимости ||Q|| графа G (рисунок 6.10).

H

4

5

6

7

8

9

4

0

1

0

1

0

0

5

1

0

1

1

0

0

6

0

1

0

1

0

0

7

1

1

1

0

1

1

8

0

0

0

1

0

1

9

0

0

0

1

1

0

Q

4

5

6

7

8

9

4

1

1

0

1

0

0

5

1

1

1

1

0

0

6

0

1

1

1

0

0

7

1

1

1

1

1

1

8

0

0

0

1

1

1

9

0

0

0

1

1

1

Рисунок 6.10 ― Матрицы ||H|| и ||Q|| графа G

В матрице || Q|| сформируем блоки, используя метод визуального анализа и перестановок строк (т.е. стоки меняются местами) и перестановок столбцов (т.е. столбцы меняются местами). В итоге получим матрицу ||Q|| на рисунке 6.11.

Q

8

9

7

4

5

6

8

1

1

1

0

0

0

9

1

1

1

0

0

0

7

1

1

1

1

1

1

4

0

0

1

1

1

0

5

0

0

1

1

1

1

6

0

0

1

0

1

1


Рисунок 6.11 ― Матрица || Q || с тремя выделенными блоками

Анализ матрицы || Q || на рисунке 6.11 показывает, что поскольку число блоков равно трем, то имеем три полных подграфа G с тремя вершинами в каждом (1-ый блок: 3х3, 2-ой блок: 3х3, 3-ий блок: 2х2). Иными словами, |Х`1|=3, |Х`2|=3, |Х`3|=2 (рисунок 6.12).

Рисунок 6.12 ― Три подграфа графа G

Обозначения: пунктиром выделены полные подграфы графа G.

Таким образом имеем:

.

Расчет неплотности ε(G) графа G

Рассмотрим плотность графа G, т.е. наибольшее число вершин пустого подграфа графа G между всеми вершинами которого нет отношений смежности.

Построим обратный граф ┐G для графа G. Для этого получим матрицу || H || и обратную ей матрицу || ┐H || (рисунок 6.13).

H

4

5

6

7

8

9

4

0

1

0

1

0

0

5

1

0

1

1

0

0

6

0

1

0

1

0

0

7

1

1

1

0

1

1

8

0

0

0

1

0

1

9

0

0

0

1

1

0

H

4

5

6

7

8

9

4

1

0

1

0

1

1

5

0

1

0

0

1

1

6

1

0

1

0

1

1

7

0

0

0

1

0

0

8

1

1

1

0

1

0

9

1

1

1

0

0

1

Рисунок 6.13 ― Матрицы смежности (слева-направо) графа G и графа ┐G

Строим матрицу достижимости графа ┐G и выполняем операцию перестановки строк и столбцов. Результаты показаны на рисунке 6.14.

Qp

9

6

4

8

5

7

9

1

1

1

0

1

0

6

1

1

1

1

0

0

4

1

1

1

1

0

0

8

0

1

1

1

1

0

5

1

0

0

1

1

0

7

0

0

0

0

0

1

Qp

4

5

6

7

8

9

4

1

0

1

0

1

1

5

0

1

0

0

1

1

6

1

0

1

0

1

1

7

0

0

0

1

0

0

8

1

1

1

0

1

0

9

1

1

1

0

0

1

Рисунок 6.14 ― Матрицы достижимости ┐Qp графа ┐G

Примечание: матрица на рисунке справа имеет блочную структуру.

На рисунке 6.15 показан обратный граф ┐G.

Рисунок 6.15 - Обратный граф ┐G

Анализ матрицы ┐Qp с блочной структурой на рисунке 6.14 показывает, что поскольку число блоков – три, то имеем три пустых подграфа графа G (рисунок 6.16):

|Х`1|=3, |Х`2|=3, |Х`3|=2.

Рисунок 6.16 - Три пустых подграфа графа G

Таким образом имеем:

.

Расчет внешней устойчивости ψ(G) графа G

Рассчитаем внешнюю устойчивость графа G, т.е. наименьшее число вершин графа G смежных со всеми остальными вершинами графа.

Составим таблицу 6.2 отображений для графа G и дополним ее столбцом несмежных вершин.

Таблица 6.2 ― Таблица отображений графа G

xi

Hi

Hi

4

5,7

6,8,9

5

4,6,7

8,9

6

5,7

4,8,9

7

4,5,6,8,9

8

7,9

4,5,6

9

7,8

4,5,6

Анализ таблицы 6.2 показывает, что в столбце ┐Hi есть несмежные вершины. В этом случае необходимо построить еще одну таблицу – таблицу 6.3 следующим образом.

Таблица 6.3 строится на базе строк таблицы 6.2, в которых нет знака в столбце ┐Hi. В нашем случае таких строк – пять. В строках первого столбца таблицы 6.3 пары вершин, образованные полным перебором вершин из первого и второго столбцов таблицы 6.2. В строках второго и третьего столбцов таблицы 6.3 указываются смежные и несмежные вершины, соответственно, для ij}, перечисляемых в строках первого столбца таблицы 6.3.

Таблица 6.3 ― Таблица отображений и несмежных вершин для двухэлементных подмножеств

{xi,xj}

H(xi,xj)

H(xi,xj)

x4,x5

x6,x7

x8,x9

x4,x7

x5,x6,x8,x9

x5,x6

x4x7

x8,x9

x5,x7

x4,x6,x8,x9

x7,x6

x5,x8,x9

x4

x7,x8

x4,x5,x6,x9

x7,x9

x4,x5,x6,x8

x8,x9

x7

x4,x5,x6

Если в таблице 6.3 найдется , т.е. хотя бы в одной строке столбца 3 таблицы 6.3 будет стоять знак , то расчеты завершены. В противном случае необходимо перейти к формированию новых таблиц отображений и несмежных вершин для трех элементных подмножеств , т.е. H(xi,xj,xk) и ┐H(xi,xj,xk) и т.д.

В нашем примере во второй, четвертой, шестой и седьмой строках стоят знаки . Значит расчеты закончены и можно приступать к анализу таблицы 6.2 и таблицы 6.3.

По итогам анализа таблицы 6.3 можно сформировать множество T потенциальных ядер графа G, т.е.

Т= {{ x4,x5},{ x4,x7},{x7,x8},{x7, x4}},

где T1={ x4,x5}, T2={x5,x7}, T3={x7,x8}, T4={x7, x4}.

Тогда ψ(G)= {| |}= | |}|i=1;4=2.

Расчет числа внутренней устойчивости (G) графа G

Составим таблицу 6.2 отображений и несмежных вершин графа G. Анализ таблицы 6.2 показывает, что в столбце ┐Hi есть несмежные вершины. В этом случае построим таблицу 6.4 двухэлементных множеств из несмежных вершин, найдем им образ и ┐ .

Таблица 6.4 - Таблица образов и ┐

{xi,xj}

4,6

5,7

8,9

4,8

5,7,9

6,9

4,9

5,7,8

6

5,8

4,6,7,9

5,9

4,6,7,8

6,8

5,7,9

4

6,9

5,7,8

4


Поскольку не во всех строках столбца ┐ таблицы 6.4 указаны знаки , сформируем таблицу 6.5 трехэлементных множеств {xi,xj,xk} и найдем им образ и ┐ .

Таблица 6.5 - Таблица образов и

{xi,xj,xk}

4,6,8

5,7,9

4,6,9

5,8,7


Поскольку во всех строках таблицы 5.5 указаны знаки процесс вычислений закончен и можно перейти к анализу таблицы 6.4 и таблицы 6.5.

По итогам анализа можно сформировать множество S ядер графа G, т.е.

S={{x5,x8},{x5,x4},{x4,x6,x8,},{x4,x6,x9}},

где S1={x5,x8}, S2={x5,x9}, S3={x4,x6,x8}, S4={x4x6,x6}.

Тогда

(G)= {|Si|}= {| |}|i=1;4=3.

На этом расчеты числовых характеристик графа G закончены.