Essays.club - Получите бесплатные рефераты, курсовые работы и научные статьи
Поиск

Графы

Автор:   •  Декабрь 5, 2021  •  Практическая работа  •  1,632 Слов (7 Страниц)  •  186 Просмотры

Страница 1 из 7

Министерство образования и науки Российской Федерации

Федеральное государственное бюджетное образовательное учреждение высшего образования

«ТОМСКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ СИСТЕМ УПРАВЛЕНИЯ И РАДИОЭЛЕКТРОНИКИ» (ТУСУР)

Кафедра комплексной информационной безопасности электронно-вычислительных систем (КИБЭВС)

ГРАФЫ

Отчет по практической работе №6                                                                              по дисциплине «Структуры данных»

Студент гр. :

________

__.__.2021

 

Руководитель  

Доцент каф. КИБЭВС  

_________

__.__.2021

Томск 2021

Содержание

Введение        3

Основная часть        4

Заключение        6

Приложение        7


1 Введение

Цель работы: получить навыки и освоить способы представления графов. Реализовать различные алгоритмы для работы с графом. Для написания программ в данной практической работе будет использоваться язык программирования C#.

В практической работе выполняется задание варианта №7.

Реализовать возможность работы с графом N узлов, M ребер. Выберете самостоятельно структуру. Обеспечьте следующие интерфейсные методы:

  • ввод графа (можно случайным образом);
  • вывод графа - матрица смежности или весов.

Задана система дорог. Найти такой город, для которого сумма расстояний до остальных городов максимальна.


2 Основная часть

С помощью языка программирования C# была реализована неориентированная матрица смежности для вывода графа и дальнейшей работы с ним (см. Приложение А).

На рисунке 1 представлен код функции CreateMatrix() которая реализовывает ввод графа. Создается двумерный массив и с помощью цикла for рандомно происходит его заполнение. В строке кода 16 происходит заполнение главной диагонали нулями, относительно этой диагонали элементы матрицы будут симметричны. В строке кода 20 реализуется обратной порядок для симметрии матрицы.

[pic 1]

Рисунок 1 – Функция CreateMatrix()

На рисунке 2 представлен код функции PrintMatrix() которая реализовывает вывод графа. На вход функции подается уже заполненная числами матрица и размерность массива.

[pic 2]

Рисунок 2 – Функция PrintMatrix()

На рисунке 3 представлен код функции CountDist() которая находит город, для которого сумма расстояний до остальных городов максимальна. Создаются 2 переменные chislo и gorod которые впоследствии используются для вывода информации о сумме расстояний и городе на экран. В строках кода 42–45 находится сумма всех элементов в строке матрицы.

[pic 3]

Рисунок 3 – Функция CountDist()

На рисунке 4 представлен код функции Floid() которая реализовывает алгоритм Флойда для нахождения длины кратчайших путей.

[pic 4]

Рисунок 4 – Функция Floid()

Пример работы программы изображен на рисунке 5.

[pic 5]

Рисунок 5 – Работа программы


3 Заключение

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

...

Скачать:   txt (8.8 Kb)   pdf (145.8 Kb)   docx (94.4 Kb)  
Продолжить читать еще 6 страниц(ы) »
Доступно только на Essays.club