Графическое представление графа
Московский Авиационный Институт
(Государственный Технический Университет)
филиал «Восход»
Кафедра МиПОИС
Лабораторная работа
по дискретной математике
«Графическое представление графа»
(отчет)
Преподаватель ____________ /Крохина Н.В./
Студент группы ДМ 2-26 ___________ /Толоконников А.В./
г. Байконур
2002 г.
1. Задача
Составить алгоритм перехода к графическому представлению для неориентированного графа и реализовать его программным путем, если граф задан матрицей смежностей.
2. Алгоритм решения, поставленной задачи
1) Вводится количество вершин неориентированного графа.
2) Если количество вершин больше 7, то переходим к пункту 3; иначе переходим к пункту 4.
3) Генератором случайных чисел произвольно задаются связи между вершинами в матрице смежностей, переходим к пункту 5.
4) Вводятся связи между вершинами, исходя из следующего условия: не существует пути длиной в одно ребро из одной вершины в другую – ставим «0», существует путь между двумя вершинами длиной в одно ребро – ставим «1», существует путь из вершины в саму себя – ставим «2». Все введенные данные заносятся в матрице смежностей.
5) В зависимости от количества введенных вершин производится разбиение экрана на N секторов относительно центра экрана.
6) На граничных линиях секторов на одинаковом удалении от центра экрана выводим вершины.
7) Производим чтение из матрицы смежностей. Если связь между вершинами есть, то выводим на экран отрезок, соединяющий одну вершину с другой, если связи нет - рассматриваем следующую связь. Если связь циклическая изменяем цвет вершины с зеленого на коричневый.
3. Распечатка программы решения задачи
Program Graphs;
Uses Crt, Graph;
Const
M=25; {Предельное число вершин графа}
R=200; {Радиус окружности, на которой лежат вершины (центры окружностей)}
Type
Koor = Record
X,Y: Integer
End;
MasKoor = Array(1..M) Of Koor;
Smezno = Array(1..M,1..M) of Integer;
Var
Driver, Mode,
N,I,J: Integer; {Количество вершин графа}
A: MasKoor;
B: Smezno;
Procedure Koordinata; {Процедура задания координат вершин в зависимости от количества секторов}
Var
Q,W: Real;
Begin
Writeln('Введите количество вершин графа: ');
Readln(N);
If N>M Then Halt;
Q:=6.28/N;
{Задание координат вершин графа}
For I:=1 To N Do
Begin
W:=I*Q;
A(I).X:=300+Trunc(R*cos(W));
A(I).Y:=235+Trunc(R*sin(W));
End
End;
Procedure Vivod; {Вывод вершин графа на экран монитора}
Begin
For I:=1 To N Do
Begin
SetBkColor(0);
SetColor(2);
For J:=1 To 10 Do
Circle(A(I).X,A(I).Y,J)
End
End;
Procedure Smegnost; {Процедура задания матрицы смежностей}
Begin
For I:=1 To N Do
For J:=1 To N Do
B(I,J):=9;
If N>7 Then
For I:=1 To N Do
For J:=1 To N Do
B(I,J):=Random(3)
else
Begin
For I:=1 To N Do
For J:=1 To N Do
If B(I,J)=9 Then
Begin
Write('Введите связь (',I,',',J,'):= ');
Readln(B(I,J));
B(J,I):=B(I,J)
End
Else Writeln('Cвязь (',I,',',J,'):= ',B(I,J));
End
End;
Procedure Linia;
Var K: Integer;
Begin
For I:=1 To N Do
For J:=1 To N Do
If (I=J) And (B(I,J)=2) Then {Циклическая связь}
Begin
SetColor(Brown);
For K:=1 To 10 Do
Circle(A(I).X,A(I).Y,K)
End else
If B(I,J)=1 Then {Обычная связь}
Begin
SetColor(Red);
Line(A(I).X,A(I).Y,A(J).X,A(J).Y)
End
End;
{------------------------------------------------------------------}
Begin
ClrScr;
WriteLn('Вывод изображения графа на экран монитора');
Koordinata;
Smegnost;
Readln; {Задержка экрана}
Driver:=Detect;
InitGraph(Driver,Mode,'Egavga.bgi'); {Подключение графического режима}
Vivod;
Linia;
Readln;
Closegraph; {Отключение графического режима}
End.
неориентированный граф вершина матрица
4. Результаты работы программы для числа вершин равного 6
Матрица смежностей вершин | ||||||
A | B | C | D | E | F | |
A | 0 | 0 | 1 | 0 | 0 | 1 |
B | 0 | 0 | 1 | 1 | 0 | 1 |
C | 0 | 1 | 0 | 0 | 1 | 1 |
D | 1 | 0 | 1 | 2 | 1 | 0 |
E | 0 | 0 | 1 | 0 | 2 | 0 |
F | 1 | 0 | 1 | 0 | 1 | 2 |
Категории:
- Астрономии
- Банковскому делу
- ОБЖ
- Биологии
- Бухучету и аудиту
- Военному делу
- Географии
- Праву
- Гражданскому праву
- Иностранным языкам
- Истории
- Коммуникации и связи
- Информатике
- Культурологии
- Литературе
- Маркетингу
- Математике
- Медицине
- Международным отношениям
- Менеджменту
- Педагогике
- Политологии
- Психологии
- Радиоэлектронике
- Религии и мифологии
- Сельскому хозяйству
- Социологии
- Строительству
- Технике
- Транспорту
- Туризму
- Физике
- Физкультуре
- Философии
- Химии
- Экологии
- Экономике
- Кулинарии
Подобное:
- Динамические структуры данных. Решение задач. Стек. Очередь. Дек
Для решения многих практических задач используются структуры данных – массив, запись, множество и так далее. Цель описания типов данны
- Исследование метода дифференцирования по параметру для решения нелинейных САУ
Министерство образования и науки Российской ФедерацииНовосибирский Государственный Технический УниверситетКафедра экономической и
- Исследование метода продолжения решения по параметру для нелинейных САУ
1. Постановка задачи (математическое описание метода)2. Описание программного обеспечения2.1 Общие сведения и требования к ПО и описание
- Исследование неявного метода Эйлера для линейной системы ОДУ с постоянным и переменным шагом
Министерство Образования РФНГТУКафедра экономической информатикиКурсовая работа по курсу«Численные методы в экономике»:Исследован
- Інтерполювання функцій
Зміст ВступРозділ IІнтерполювання функцій1.1 Постановка задачі1.2 Інтерполяційні формули Ньютона1.2.1 Перша інтерполяційна формула Нью
- Качественное исследование модели хищник-жертва
В настоящее время задачи экологии имеют первостепенное значение. Важным этапом решения этих задач является разработка математических
- Конечно-разностный метод решения для уравнений параболического типа
К дифференциальным уравнениям с частными производными приходим при решении самых разнообразных задач. Например, при помощи дифференци
Copyright © https://referat-web.com/. All Rights Reserved