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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Рассчитать время, нужное, чтобы добраться до ближайшего из эвакуационных выходов (файловый ввод/вывод) http://www.cyberforum.ru/cpp-beginners/thread841224.html
Эвакуация Одна из Сверхсекретных организаций, чье название мы не имеем право разглашать, представляет собой сеть из N подземных бункеров, соединенных равными по длине туннелями, по которым из любого бункера можно добраться до любого другого (не обязательно напрямую). Связь с внешним миром осуществляется через специальные засекреченные выходы, которые расположены в некоторых из бункеров....
C++ Ошибка undefined reference to При сборке выбивает ошибку: undefined reference to `Atom:: DoBCC(float, int, int, int)'. Ткните носом, пожалуйста, где ошибка. Заранее благодарен. main.cpp #include <iostream> #include "Atom.h" using std::cout; using std::cin; using std::endl; http://www.cyberforum.ru/cpp-beginners/thread841222.html
C++ Ввод данных в файл
Всем привет. Возникла вот такая проблема. вот часть программы точней функция из программы, ну тут все понятно. char frazza; cout<<"Введите фразу которую вы хотите поместить в файл -->> "; cin>>frazza; ofstream fout("MyFile.txt", ios_base::trunc); fout <<frazza; fout.close();
C++ Определите общее количество отрицательных элементов,расположенных в тех строках матрицы, каждая из которых содержит хотя бы один отрицательный элемент
помогите пожалуйста написать прогу на С++
C++ Вариативная часть структур http://www.cyberforum.ru/cpp-beginners/thread841183.html
Здравствуйте, нужна помощь с определением вариативной части структуры. Задание: Разработать структуру с вариативной частью для представления информации об объекте. Диск. Общие поля: название, год. Вариативные поля: для аудио – количество треков, для видео – разрешение. struct Disk { char Name;
C++ Дано массив слов, и в каждом слове от 1 до 8 малых латинских букв. Вывести те слова, у которых буквы стоят по алфавиту Дано массив слов, и в каждом слове от 1 до 8 малых латинских букв. Вывести те слова, у которых буквы стоят по алфавиту подробнее

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

Задание

Напишите программу 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.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru