Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 24.01.2013
Сообщений: 99
1

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

18.04.2013, 02:43. Показов 1347. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
С целью подготовки к проведению олимпиады по информатике мэр решил обеспечить надежным электроснабжением все школы города. Для этого необходимо провести линию электропередач от альтернативного источника электроэнергии “Майбуття” к одной из школ города (к какой неважно), а также соединить линиямии электропередач некоторые школы между собой. Считается, что школа имеет надежное электроснабжение, если она напрямую связана с источником “Майбуття”, либо с одной из тех школ, которые имеют надежное электроснабжение. Известна стоимость соединения между некоторыми парами школ. Мэр города решил выбрать одну из двух наиболее экономичных схем электроснабжения (стоимость схемы равняется сумме стоимостей соединений пар школ).

Задание

Напишите программу 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.
1
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.04.2013, 02:43
Ответы с готовыми решениями:

Программа которая вычисляет общую стоимость товара
Ребята привет всем. Нужно написать вот такую программу. Вот задания Реализовать программу в среде...

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

Программа вычисляет стоимость поездки на автомобиле
спасибо! Помогите ещё тогда плиз с этой: Программа вычисляет стоимость поездки на автомобиле,...

Написать программу которая вычисляет стоимость покупки с учетом скидки
Скидка 1% предоставляется, если сумма покупки больше 300 рублей, 2% - если сумма больше 500 рублей,...

0
18.04.2013, 02:43
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.04.2013, 02:43
Помогаю со студенческими работами здесь

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

Функция вычисляет по двум катетам по теореме Пифагора гипотенузу. Составить программу которая вычисляет гипотенузу двух любых сторон
Функция вычисляет по двум катетам по теореме Пифагора гипотенузу. Составить программу которая...

Написать функцию, которая вычисляет сопротивление двух резисторов
N.1.Написать функцию, которая вычисляет сопротивление двух резисторов. Входными данными в функции...

Написать функцию, которая вычисляет сопротивление двух резисторов
Написать функцию, которая вычисляет сопротивление двух резисторов. Входными данными в функции...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru