Professional Documents
Culture Documents
Лаб №2
Лаб №2
Ігоря Сікорського»
Факультет інформатики та обчислювальної техніки
Кафедра інформаційних систем та технологій
Лабораторна робота №2
з дисципліни «СРМ-1. Дискретна математика»
на тему
«Характеристики графів»
Київ – 2021
Зміст
Зміст............................................................................................................................2
1 Постановка задачі..................................................................................................3
2 Результати виконання програми...........................................................................4
3 Лістинг програми.....................................................................................................5
1 Постановка задачі
a. Діаметр графу
b. Радіус графу
c. Центр графу
d. Яруси графу із переліком вершин, які входять до кожного ярусу
2 Результати виконання програми
З файлу зчитується кількість вершин та ребер графу. Граф заданий списком
ребер.
E5 E7
5
E4
1 E2 E3 4
E6
E1
E1
2 3
Рис. графу
3 Лістинг програми
#include <iostream>
#include <fstream>
#include <iomanip>
#include <string>
#include <windows.h>
using namespace std;
int main()
{
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
ifstream inputFile("graph.txt");
int n, m;
inputFile >> n >> m;
int** array;
array = new int* [m];
for (int i = 0; i < m; i++) {
array[i] = new int[0];
}
for (int i = 0; i < m; i++) {
inputFile >> array[i][0] >> array[i][1];
}
inputFile.close();
cout << "З файлу було зчитано такі значення: " << endl;
for (int i = 0; i < m; i++) {
cout << array[i][0] << " " << array[i][1] << endl;
}
//------Матриця суміжності---------//
int** symiznist = new int* [n + 1]; //розмір матриці - n x n
for (int i = 0; i < n + 1; i++) {
symiznist[i] = new int[n + 1];
}
for (int i = 0; i < n + 1; i++) {
for (int j = 0; j < n + 1; j++) {
symiznist[i][j] = 0;
}
}
for (int i = 0; i < n + 1; i++) {
for (int j = 0; j < n + 1; j++) {
symiznist[i][0] = i;
symiznist[0][j] = j;
}
}
for (int i = 0; i < m; i++) {
p = array[i][0];
t = array[i][1];
symiznist[p][t] = 1;
}
cout << "Матриця інцидентності: " << endl;
for (int i = 0; i < n + 1; i++) {
for (int j = 0; j < m + 1; j++) {
cout << setw(4) << incid[i][j] << " ";
}
cout << endl;
}
cout << endl << "Матриця суміжності: " << endl;
for (int i = 0; i < n + 1; i++) {
for (int j = 0; j < n + 1; j++) {
cout << setw(4) << symiznist[i][j] << " ";
}
cout << endl;
}
char choice;
int vhid;
for (int i = 0; i < n + 1; i++) {
vhid = 0;
for (int j = 1; j <= n; j++) {
if (symiznist[j][i] == 1) {
vhid++;
}
}
if (i >= 1)
cout << "Півстепінь входу " << i << " вершини: " << vhid << endl;
}
cout << endl;
int counter = 0;
for (int i = 0; i < n; i++) {
cout << "Степінь " << i + 1 << " вершини: " << stepin[i] << endl;
if (stepin[i] == stepin[i+1])
counter++;
}
if (counter == n)
cout << endl << "Граф однорідний" << endl;
else cout << endl << "Граф неоднорідний" << endl;
}
system("pause>0");
}