Главная Рефераты по рекламе Рефераты по физике Рефераты по философии Рефераты по финансам Рефераты по химии Рефераты по хозяйственному праву Рефераты по цифровым устройствам Рефераты по экологическому праву Рефераты по экономико-математическому моделированию Рефераты по экономической географии Рефераты по экономической теории Рефераты по этике Рефераты по юриспруденции Рефераты по языковедению Рефераты по юридическим наукам Рефераты по истории Рефераты по компьютерным наукам Рефераты по медицинским наукам Рефераты по финансовым наукам Рефераты по управленческим наукам Психология и педагогика Промышленность производство Биология и химия Языкознание филология Издательское дело и полиграфия Рефераты по краеведению и этнографии Рефераты по религии и мифологии Рефераты по медицине Рефераты по сексологии Рефераты по информатике программированию Краткое содержание произведений |
Лабораторная работа: Графическое представление графаЛабораторная работа: Графическое представление графаМосковский Авиационный Институт(Государственный Технический Университет) филиал «Восход» Кафедра МиПОИСЛабораторная работапо дискретной математике«Графическое представление графа» (отчет) Преподаватель ____________ /Крохина Н.В./ Студент группы ДМ 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
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|