Форум программистов, компьютерный форум CyberForum.ru

Программа SCHOOLS, которая вычисляет стоимость двух наиболее экономных схем альтернативного электроснабжения школ - C++

Восстановить пароль Регистрация
 
tvboy
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 99
18.04.2013, 02:43     Программа SCHOOLS, которая вычисляет стоимость двух наиболее экономных схем альтернативного электроснабжения школ #1
С целью подготовки к проведению олимпиады по информатике мэр решил обеспечить надежным электроснабжением все школы города. Для этого необходимо провести линию электропередач от альтернативного источника электроэнергии “Майбуття” к одной из школ города (к какой неважно), а также соединить линиямии электропередач некоторые школы между собой. Считается, что школа имеет надежное электроснабжение, если она напрямую связана с источником “Майбуття”, либо с одной из тех школ, которые имеют надежное электроснабжение. Известна стоимость соединения между некоторыми парами школ. Мэр города решил выбрать одну из двух наиболее экономичных схем электроснабжения (стоимость схемы равняется сумме стоимостей соединений пар школ).

Задание

Напишите программу SCHOOLS, которая вычисляет стоимость двух наиболее экономных схем альтернативного электроснабжения школ.

Входные данные

В первой строке входного файла SCHOOLS.DAT находятся два натуральных числа, разделенных пробелом: N (3 £ N £ 100), количество школ в городе, и M – количество возможных соединений между ними. В каждой из последующих M строк находятся по три числа: Ai, Bi, Ci, разделенных пробелами, где Ci – стоимость прокладки линии электроснабжения (1 £ Ci £ 300) от школы Ai до школы Bi (i=1,2,…,N).

Пример входного файла

5 8

1 3 75

3 4 51

2 4 19

3 2 95

2 5 42

5 4 31

1 2 9

3 5 66

Выходные данные

В единственной строке выходного файла SCHOOLS.SOL должны содержаться два натуральных числа S1 и S2, разделенных пробелом – две наименьшие стоимости схем (S1£S2). S1=S2 тогда и только тогда, когда существует несколько схем надежного электроснабжения наименьшей стоимости.

Пример выходного файла

110 121
Pascal
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
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
{$A+,B-,D+,E+,F-,G-,I+,L+,N-,O-,P-,Q+,R+,S+,T-,V+,X+}
 
{$M 16384,0,655360}
 
const
 
MaxN = 100;
 
FileIn = 'schools.dat';
 
FileOut = 'schools.sol';
 
type
 
PList = ^TList;
 
TList = record
 
Ver, Leng : integer;
 
Next : PList;
 
end;
 
var
 
A : array [1..MaxN, 1..MaxN] of integer;
 
{ Adjacency matrix for graph}
 
Dist : array [1..MaxN,1..2] of integer;
 
BestTree : array [1..MaxN] of PList;
 
{ Each element of array cotains a reference to list of the verteses that are reachable from the vertex with number equal to the index of element}
 
Dynamic : array [1..MaxN, 1..MaxN] of integer;
 
{ Array contains matrix of maximal edge's length at first spannig tree}
 
{List : array [1..(MaxN*(MaxN-1) div 2), 1..3] of integer;}
 
{ Array contains the list of edges
 
1 - first vertex of edge
 
2 - second vertex of edge
 
3 - length of current edge
 
4 - value of this element set to '1' if the edge is usedat first spanning tree} 
 
N, M : integer; {the number of vertex, and the number of edges}
 
FirstAnswer, SecondAnswer : integer; {Answers}
 
Fi, Fo : Text; {Input and Output file handlers} 
 
Root : integer; { Global variable that used for build of dynamic array} 
 
{Testing procedures}
 
procedure PrintDynamic;
 
var i,j : integer;
 
begin
 
WriteLn('--- Dynamic ------------');
 
for i:=1 to n do
 
begin
 
for j:=1 to n do
 
Write(Dynamic[i,j]:4);
 
WriteLn;
 
end;
 
end;
 
{Working procedures}
 
{work with list}
 
procedure ListAdd(i, v, l : integer);
 
var
 
p : PList;
 
begin
 
New(p);
 
P^.Next:=BestTree[i];
 
P^.Ver:=v;
 
P^.Leng:=l;
 
BestTree[i]:=P;
 
end;
 
procedure ListDispose(p : PList);
 
begin
 
if p=nil then exit;
 
ListDispose(p^.Next);
 
Dispose(p);
 
end;
 
procedure BestTreeDispose;
 
var i : integer;
 
begin
 
for i:=1 to n do
 
ListDispose(BestTree[i]);
 
end;
 
procedure BuildDist;
 
var i : integer;
 
begin
 
Dist[1,1]:=-1;
 
Dist[1,2]:=-1;
 
for i:=2 to N do
 
begin
 
Dist[i,1]:=A[1,i];
 
Dist[i,2]:=1;
 
end;
 
end;
 
function MinInt (a, b : integer) : integer;
 
begin if a<b then MinInt:=a else MinInt:=b;
 
end;
 
function MaxInt (a, b : integer) : integer;
 
begin if a>b then MaxInt:=a else MaxInt:=b;
 
end;
 
procedure Init;
 
var i,x,y,l,j : integer;
 
begin
 
for i:=1 to MaxN do BestTree[i]:=nil;
 
FillChar(A, SizeOf(A), 0); {0 = infinty}
 
FillChar(Dist, SizeOf(Dist), 0); {0 = infinty}
 
FillChar(Dynamic, SizeOf(Dynamic), 0);
 
Assign(Fi, FileIn);
 
Reset(Fi);
 
Readln(Fi, N, M);
 
for i:=1 to M do
 
begin
 
ReadLn(Fi, y, x, l);
 
A[y, x]:=l;
 
A[x, y]:=l;
 
end;
 
Close(Fi);
 
SecondAnswer:=0;
 
end;
 
procedure BuildSpanningTree;
 
var i,j, MinPos : integer;
 
begin
 
FirstAnswer:=0;
 
BuildDist;
 
for i:=2 to n do
 
begin
 
MinPos:=0;
 
for j:=1 to n do
 
if Dist[j, 1]>0 then
 
if (MinPos=0) then MinPos:=j else
 
if Dist[j, 1]<Dist[MinPos, 1] then MinPos:=j;
 
FirstAnswer:=FirstAnswer + Dist[MinPos, 1];
 
ListAdd(MinPos, Dist[MinPos, 2], Dist[MinPos, 1]);
 
ListAdd(Dist[MinPos, 2], MinPos, Dist[MinPos, 1]);
 
Dynamic[MinPos, Dist[MinPos, 2]]:=Dist[MinPos, 1];
 
Dynamic[Dist[MinPos, 2], MinPos]:=Dist[MinPos, 1];
 
A[MinPos, Dist[MinPos, 2]]:=-1;
 
A[Dist[MinPos, 2], MinPos]:=-1;
 
Dist[MinPos, 1]:=-1;
 
Dist[MinPos, 2]:=-1;
 
for j:=1 to n do
 
if Dist[j, 1]>-1 then
 
if Dist[j, 1]=0 then
 
begin
 
Dist[j, 1]:=A[MinPos, j];
 
Dist[j, 2]:=MinPos;
 
end else
 
if (A[j, MinPos]>0)and(Dist[j, 1]>A[j, MinPos]) then
 
begin
 
Dist[j, 1]:=A[MinPos, j];
 
Dist[j, 2]:=MinPos;
 
end;
 
end;
 
end;
 
procedure BuildDynamic(Curr, Prev : integer);
 
var
 
i : integer;
 
p : PList;
 
begin
 
p:=BestTree[Curr];
 
while p<>nil do
 
begin
 
if (p^.Ver <> Prev) then
 
begin
 
Dynamic[Root, p^.Ver]:=MaxInt(p^.Leng, Dynamic[Root, Curr]);
 
BuildDynamic(p^.Ver, Curr);
 
end;
 
p:=p^.Next;
 
end;
 
end;
 
procedure LookForEdge;
 
var i, j, Calc : integer;
 
begin
 
SecondAnswer:=32000;
 
for i:=1 to N do
 
for j:=1 to N do
 
if A[i, j]>0 then
 
begin
 
Calc:=(FirstAnswer-Dynamic[i, j]) + A[i, j];
 
if SecondAnswer>Calc then SecondAnswer:=Calc;
 
end;
 
end;
 
procedure Run;
 
begin
 
{first ostov; algorith Prima}
 
BuildSpanningTree;
 
{second ostov}
 
for Root:=1 to n do
 
BuildDynamic(Root, Root);
 
{PrintDynamic;} {Test}
 
LookForEdge;
 
end;
 
procedure Done;
 
begin
 
BestTreeDispose;
 
Assign(Fo, FileOut);
 
Rewrite(Fo);
 
WriteLn(Fo, FirstAnswer, ' ', SecondAnswer);
 
Close(Fo);
 
end;
 
begin
 
Init; {Initialization}
 
Run; {Calculation}
 
Done; {Printing answer}
 
end.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.04.2013, 02:43     Программа SCHOOLS, которая вычисляет стоимость двух наиболее экономных схем альтернативного электроснабжения школ
Посмотрите здесь:

C++ Написать функцию, которая вычисляет сопротивление двух резисторов
Описать процедуру, которая вычисляет сумму элементов двух одномерных массивов C++
Написать программу, которая вычисляет значение функции от двух аргументов Х и У C++
Написать функцию, которая вычисляет сопротивление двух резисторов C++
C++ 5. Написать функцию, которая вычисляет сопротивление цепи, состоящей из двух резисторов
Программа на языке С++, которая вычисляет условие: C++
C++ Программа, которая вычисляет длину введенной с клавиатуры строки
C++ Программа, которая вычисляет польскую инверсную запись
Напишите функцию, которая вычисляет наибольший общий делитель двух чисел C++
C++ Программа, которая вычисляет квадрат и куб чисел от 0 до 10
C++ Программа, сравнивающая стоимость двух товаров
программа, которая вычисляет количество элементов одномерного массива Х C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 09:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru