#1136
Dragoni
Supărați că lansarea părții a treia a filmului lor preferat s-a amânat până în iunie 2018, Henry și Hetty s-au gândit la propriul scenariu pentru finalul trilogiei:
Într-o lume în care vikingii pot zbura cu dragonii există N
insule. Hiccup, șeful tribului de vikingi aflat pe insula 1
, știe M
rute directe de zbor bidirecționale între insule. Pentru fiecare j
intre 1
si M
, ruta j
unește insulele A
j
și B
j
și are lungime D
j
.
Pe fiecare insulă i
, (1 ≤ i ≤ n
) există dragoni din specia i
care pot zbura fără a se opri pentru odihnă o distanță maximă Dmax
i
. Cu alte cuvinte, dragonii de pe insula i
vor putea parcurge orice rută j
, (1 ≤ j ≤ m
) pentru care D
j
≤ Dmax
i
, indiferent de ce alte drumuri au făcut anterior.
Hiccup dorește să ajungă de pe insula 1
pe insula N
pentru a-l salva pe Toothless, dragonul lui. Pentru a ajunge acolo, el va lua inițial un dragon din specia 1
(de pe insula 1
). Apoi, dacă la un moment dat Hiccup se află pe o insula i
, (1 ≤ i ≤ n
) având cu el un dragon din specia t
, el poate:
i
pe o altă insulă x
cu dragonul pe care îl are, folosind o rută directă j
între insulele i
si x
, bineînțeles doar dacă D
j
≤ Dmax
t
.t
pe care îl are cu un dragon din specia i
aflat pe insula respectivă.Cerințe:
a. Să se determine distanța maxima Dmax
i
caracteristică unui dragon la care Hiccup poate ajunge fără a schimba dragonul pe care l-a luat inițial de pe insula 1
.
b. Să se determine distanța minimă pe care Hiccup trebuie să o parcurgă pentru a ajunge de pe insula 1
pe insula N
.
OJI 2015, Clasele XI-XII
Problema | Dragoni | Operații I/O |
dragoni.in /dragoni.out
|
---|---|---|---|
Limita timp | 1.5 secunde | Limita memorie |
Total: 32 MB
/
Stivă 8 MB
|
Id soluție | #42524835 | Utilizator | |
Fișier | dragoni.cpp | Dimensiune | 2.21 KB |
Data încărcării | 09 Martie 2023, 08:35 | Scor / rezultat | Eroare de compilare |
dragoni.cpp: In function 'void citire()': dragoni.cpp:19:26: error: 'ccost' was not declared in this scope fin >> x >> y >> ccost; ^ dragoni.cpp: In function 'void bfs(int)': dragoni.cpp:34:25: error: 'vecin' was not declared in this scope if(dragon > vecin.secound) ^ dragoni.cpp: In function 'void dijkstra(int, int, std::vector<std::pair<int, int> >*)': dragoni.cpp:44:9: error: 'dp' was not declared in this scope dp[i] = INT_MAX, viz[i] = 0; ^ dragoni.cpp:45:5: error: 'dp' was not declared in this scope dp[start] = 0; ^ dragoni.cpp: In function 'int main()': dragoni.cpp:86:20: error: 'dp' was not declared in this scope if(dp[j] != INT_MAX && dp[j] != 0) ^ dragoni.cpp:88:49: error: expected ']' before '}' token lista2[i].push_back({j, dp[j}); ^ dragoni.cpp:88:50: error: no matching function for call to 'std::vector<std::pair<int, int> >::push_back(<brace-enclosed initializer list>)' lista2[i].push_back({j, dp[j}); ^ dragoni.cpp:88:50: note: candidates are: In file included from /usr/include/c++/4.8/vector:64:0, from /usr/include/c++/4.8/bits/random.h:34, from /usr/include/c++/4.8/random:50, from /usr/include/c++/4.8/bits/stl_algo.h:65, from /usr/include/c++/4.8/algorithm:62, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:64, from dragoni.cpp:1: /usr/include/c++/4.8/bits/stl_vector.h:901:7: note: void std::vector<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = std::pair<int, int>; _Alloc = std::allocator<std::pair<int, int> >; std::vector<_Tp, _Alloc>::value_type = std::pair<int, int>] push_back(const value_type& __x) ^ /usr/include/c++/4.8/bits/stl_vector.h:901:7: note: no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'const value_type& {aka const std::pair<int, int>&}' /usr/include/c++/4.8/bits/stl_vector.h:919:7: note: void std::vector<_Tp, _Alloc>::push_back(std::vector<_Tp, _Alloc>::value_type&&) [with _Tp = std::pair<int, int>; _Alloc = std::allocator<std::pair<int, int> >; std::vector<_Tp, _Alloc>::value_type = std::pair<int, int>] push_back(value_type&& __x) ^ /usr/include/c++/4.8/bits/stl_vector.h:919:7: note: no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'std::vector<std::pair<int, int> >::value_type&& {aka std::pair<int, int>&&}' dragoni.cpp:93:17: error: 'dp' was not declared in this scope fout << dp[n]; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Dragoni face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.