-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathGraph_coloring.cpp
More file actions
200 lines (183 loc) · 3.87 KB
/
Graph_coloring.cpp
File metadata and controls
200 lines (183 loc) · 3.87 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
#include "stdafx.h"
#include "conio.h"
#include "fstream"
#include "iostream"
#include "EasyBMP.h"
#include "EasyBMP_DataStructures.h"
using namespace std;
const int riba = 100;
int n;
// gretimumo matrica
int a[riba][riba];
// saugo virðûniø spalva, jei nëra tada 0
int spalvumasyvas[riba];
// saugo kiek kiekviena ið virðûniu turi gretimø virðûniø
int laipsniumasyvas[riba];
//masyvas virðûniø kurios nëra gretimos esamai virðûnei
int NN[riba];
// counteris
int NNCount;
// neliestø virðûniø skaièius
int neliestosvirsunes;
/*
RLF spalvinimas
*/
// skaitymo funkcija
void Nuskaitymas()
{
string file = "input.txt";
ifstream in(file);
in >> n;
for (int i=0; i < n; i++)
for (int j=0; j < n; j++)
in >> a[i][j];
in.close();
}
// priskiriamos nulinës reikðmës masyvam ir kintamiesiems
void pradiniaiveiksmai()
{
for (int i=0; i<n; i++)
{
spalvumasyvas[i] = 0;
laipsniumasyvas[i] = 0;
for (int j = 0; j < n; j++)
if (a[i][j] == 1)
laipsniumasyvas[i] ++;
}
NNCount = 0;
neliestosvirsunes = n;
}
// funkcija surandanti neliesta virsunia su didziausiu laipsniu
int DIDlaipsniovirsune()
{
int max = -1;
int max_i;
for (int i =0; i<n; i++)
if (spalvumasyvas[i] == 0)
if (laipsniumasyvas[i]>max)
{
max = laipsniumasyvas[i];
max_i = i;
}
return max_i;
}
// this function is for UpdateNN function
// it reset the value of scanned array
// resetina nuskanuota areju
void scannedInit(int scanned[riba])
{
for (int i=0; i<n; i++)
scanned[i] = 0;
}
// funkcija atnaujinanti masyva, mazinanti ji po kiekvieno ciklo kol pasiekiamas 0
void UpdateNN(int ColorNumber)
{
NNCount = 0;
for (int i=0; i<n; i++)
if (spalvumasyvas[i] == 0)
{
NN[NNCount] = i;
NNCount ++;
}
for (int i=0; i<n; i++)
if (spalvumasyvas[i] == ColorNumber)
for (int j=0; j<NNCount; j++)
while (a[i][NN[j]] == 1)
{
NN[j] = NN[NNCount - 1];
NNCount --;
}
}
// funkcija surandanti tinkama virsune is NN
int Paieska(int ColorNumber, int& VerticesInCommon)
{
int temp,tmp_y,y;
int scanned[riba];
VerticesInCommon = 0;
for (int i=0; i<NNCount; i++)
{
tmp_y = NN[i];
temp = 0;
scannedInit(scanned);
for (int x=0; x<n; x++)
if (spalvumasyvas[x] == ColorNumber)
for (int k=0; k<n; k++)
if (spalvumasyvas[k] == 0 && scanned[k] == 0)
if (a[x][k] == 1 && a[tmp_y][k] == 1)
{
temp ++;
scanned[k] = 1;
}
if (temp > VerticesInCommon)
{
VerticesInCommon = temp;
y = tmp_y;
}
}
return y;
}
// suranda virsune su daugiausiai gretimu virsuniu
int VirsuinesumaxlaipsniuInNN()
{
int tmp_y;
int temp, max = 0;
for (int i=0; i<NNCount; i++)
{
temp = 0;
for (int j=0; j<n; j++)
if (spalvumasyvas[NN[j]] == 0 && a[i][NN[j]] == 1)
temp ++;
if (temp > max)
{
max = temp;
tmp_y = NN[i];
}
}
return tmp_y;
}
// funkcija atliekanti spalvinima
void Spalvinimas()
{
//BMP grafas;
//grafas.SetSize(640, 480);
//grafas.SetBitDepth(32);
int x,y;
int spalvosnr = 0;
int bendrosvirsunes = 0;
while (neliestosvirsunes>0)
{
x = DIDlaipsniovirsune();
spalvosnr ++;
spalvumasyvas[x] = spalvosnr;
neliestosvirsunes --;
UpdateNN(spalvosnr);
while (NNCount>0)
{
y = Paieska(spalvosnr, bendrosvirsunes);
if (bendrosvirsunes == 0)
y = VirsuinesumaxlaipsniuInNN();
spalvumasyvas[y] = spalvosnr;
neliestosvirsunes --;
UpdateNN(spalvosnr);
// grafas(spalvosnr, bendrosvirsunes)->Green = 0;
}
// grafas.WriteToFile("bandymas.bmp");
}
}
// atspausdina nuspalvintas virsunes
void Spausdinimas()
{
for (int i = 0; i < n; i++)
cout << "Virsune: " << i+1 << " Nuspalvinta spalva nr: " << spalvumasyvas[i] << endl;
}
// main funkcija
void main()
{
Nuskaitymas();
pradiniaiveiksmai();
Spalvinimas();
Spausdinimas();
getch();
//http://www.imada.sdu.dk/~marco/Publications/Files/MIC2011-ChiGalGua.pdf
//http://www.tandfonline.com/doi/abs/10.1080/00207160701419114?journalCode=gcom20
}