Автор работы: Пользователь скрыл имя, 24 Марта 2011 в 16:58, курсовая работа
Исторически сложилось так, что теория графов зародилась двести с лишним лет назад именно в ходе решения головоломок. Очень долго она находилась в стороне от главных направлений исследований ученых, была в царстве математики на положении Золушки, чьи дарования раскрылись в полной мере лишь тогда, когда она оказалась в центре общего внимания.
Введение 3
1. Теоретическая часть 4
1.1 История возникновения теории графов 4
1.2 Основные понятия теории графов 6
1.3 Основные теоремы теории графов 9
1.4 Способы представления графов в компьютере 14
1.4.1 Требования к представлению графов 14
1.4.2 Матрица смежности 14
1.4.3 Матрица инциденций 15
1.4.4 Списки смежности 15
1.4.5 Массив дуг 15
1.5 Обзор задач теории графов 16
Заключение 17
2. Практическая часть 18
2.1. Общая характеристика задачи 18
2.2. Описание алгоритма решения задачи 19
Список использованной литературы 24
ВСЕРОССИЙСКИЙ
ЗАОЧНЫЙ ФИНАНСОВО-
КАФЕДРА
АВТОМАТИЗИРОВАННОЙ ОБРАБОТКИ ЭКОНОМИЧЕСКОЙ
ИНФОРМАЦИИ
КУРСОВАЯ РАБОТА
по дисциплине «Информатика»
на
тему «Применение
теории графов в информатике»
Исполнитель:
специальность
группа
№ зачетной книжки
Руководитель:
Туймазы – 2007
Содержание
Если вы любите решать олимпиадные задачи, то, наверное, не раз составляли таблицы, изображали объекты точками, соединяли их отрезками или стрелками, подмечали закономерности у полученных рисунков, выполняли над точками и отрезками операции, не похожие на арифметические, алгебраические или на преобразования в геометрии. То есть вам приходилось строить математический аппарат специально для решения задачи. А это означает, что вы открывали для себя начала теории графов. Исторически сложилось так, что теория графов зародилась двести с лишним лет назад именно в ходе решения головоломок. Очень долго она находилась в стороне от главных направлений исследований ученых, была в царстве математики на положении Золушки, чьи дарования раскрылись в полной мере лишь тогда, когда она оказалась в центре общего внимания.
Родоначальником теории графов принято считать математика Леонарда Эйлера (1707-1783) [3, стр. 36]. Однако теория графов многократно переоткрывалась разными авторами при решении различных прикладных задач.
Рисунок 1
Рисунок
2
Рисунок 3
рис. 4. Маршруты, цепи, циклы
Пример
В графе, диаграмма которого приведена на рис.4:
рис. 5 Эксцентриситеты вершин и центры графов (выделены).
Опираясь на приведенные выше определения теории графов, приведем формулировки и доказательства теорем, которые затем найдут свои приложения при решении задач.
Теорема 1. Удвоенная сумма степеней вершин любого графа равна числу его ребер. [1, стр. 66]
Доказательство. Пусть А1, А2, А3, ..., An — вершины данного графа, a p(A1), p(А2), ..., p(An) – степени этих вершин. Подсчитаем число ребер, сходящихся в каждой вершине, и просуммируем эти числа. Это равносильно нахождению суммы степеней всех вершин. При таком подсчете каждое ребро будет учтено дважды (оно ведь всегда соединяет две вершины).
Отсюда
следует: p(A1)+p(А2)+
... +p(An)=0,5N, или 2(p(A1)+p(А2)+
... +p(An))=N , где N —
число ребер.
Теорема 2. Число нечетных вершин любого графа четно.
Доказательство. Пусть a1, a2, a3, …, ak — это степени четных вершин графа, а b1, b2, b3, …, bm — степени нечетных вершин графа. Сумма a1+a2+a3+…+ak+b1+b2+b3+…+bm ровно в два раза превышает число ребер графа. Сумма a1+a2+a3+…+ak четная (как сумма четных чисел), тогда сумма b1+b2+b3+…+bm должна быть четной. Это возможно лишь в том случае, если m — четное, то есть четным является и число нечетных вершин графа. Что и требовалось доказать.
Следствие 1. Нечетное число знакомых в любой компании всегда четно.
Следствие 2. Число вершин многогранника, в которых сходится нечетное число ребер, четно.
Следствие
3. Число всех людей, когда-либо пожавших
руку другим людям, нечетное число раз,
является четным.
Теорема 3. Во всяком графе с n вершинами, где n больше или равно 2, всегда найдутся две или более вершины с одинаковыми степенями.
Доказательство.
Если граф имеет n
вершин, то каждая из них может иметь степень
0, 1, 2, ..., (n-1). Предположим, что в
некотором графе все его вершины имеют
различную степень, то есть, и покажем,
что этого быть не может. Действительно,
если р(А)=0, то это значит, что
А — изолированная вершина, и поэтому
в графе не найдется вершины Х со степенью
р(Х)=n-1. В самом деле, эта вершина
должна быть соединена с (n-1) вершиной,
в том числе и с А, но ведь А оказалась
изолированной. Следовательно, в графе,
имеющем n вершин, не могут быть одновременно
вершины степени 0 и (n-1). Это значит,
что из n вершин найдутся две, имеющие
одинаковые степени.
Теорема 4. Если в графе с n вершинами (n больше или равно 2) только одна пара имеет одинаковую степень, то в этом графе всегда найдется либо единственная изолированная вершина, либо единственная вершина, соединенная со всеми другими.
Доказательство
данной теоремы мы опускаем. Остановимся
лишь на некотором ее пояснении. Содержание
этой теоремы хорошо разъясняется задачей:
группа, состоящая из n
школьников, обменивается фотографиями.
В некоторый момент времени выясняется,
что двое совершили одинаковое число обменов.
Доказать, что среди школьников есть либо
один еще не начинавший обмена, либо один
уже завершивший его.
Теорема 5. Если у графа все простые циклы четной длины, то он не содержит ни одного цикла четной длины.
Суть теоремы в
том, что на этом графе невозможно
найти цикл (как простой, так и
непростой) нечетной длины, то есть содержащий
нечетное число ребер.
Теорема
6. Для того, чтобы граф был эйлеровым,
необходимо и достаточно, чтобы он был
связным и все его вершины имели четную
степень.
Теорема 7. Для того чтобы на связном графе можно было бы проложить цепь АВ, содержащую все его ребра в точности по одному разу, необходимо и достаточно, чтобы А и В были единственными нечетными вершинами этого графа.
Доказательство этой теоремы очень интересно и характерно для теории графов. Его также следует считать конструктивным (обратите внимание на то, как использована при этом теорема 3.6). Для доказательства к исходному графу присоединяем ребро (А, В); после этого все вершины графа станут четными. Этот новый граф удовлетворяет всем условиям теоремы 3.6, и поэтому в нем можно проложить эйлеров цикл Ψ. И если теперь в этом цикле удалить ребро (А, В), то останется искомая цепь АВ.