#1202
Arbvalmax
Se dă un arbore cu N
noduri numerotate de la 1
la N
cu rădăcina în nodul 1
. Fiecare nod din arborele dat are o valoare întreagă atașată. Se dau M
întrebări de forma (x, y)
, unde x
este un strămoș al nodului y
: dacă s-ar elimina toate nodurile de pe lanțul care unește x
cu y
(inclusiv nodurile x
și y
), care ar fi valoarea maximă din nodurile neeliminate?
Cunoscând numărul de noduri N
, configurația arborelui, valorile atașate celor N
noduri, și cele M
întrebări, să se răspundă la fiecare întrebare dată.
ONI 2015, Clasele XI-XII
Problema | Arbvalmax | Operații I/O |
arbvalmax.in /arbvalmax.out
|
---|---|---|---|
Limita timp | 0.8 secunde | Limita memorie |
Total: 64 MB
/
Stivă 16 MB
|
Id soluție | #50614755 | Utilizator | |
Fișier | arbvalmax.cpp | Dimensiune | 1.43 KB |
Data încărcării | 17 Aprilie 2024, 11:18 | Scor / rezultat | Eroare de compilare |
arbvalmax.cpp: In function 'void dfs2(int)': arbvalmax.cpp:40:67: error: no matching function for call to 'max(long long int&, int&)' dp2[it] = max(dp2[nod], max(best_val[nod][2], val[nod])); ^ arbvalmax.cpp:40:67: note: candidates are: In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from arbvalmax.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template<class _Tp> const _Tp& std::max(const _Tp&, const _Tp&) max(const _Tp& __a, const _Tp& __b) ^ /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template argument deduction/substitution failed: arbvalmax.cpp:40:67: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') dp2[it] = max(dp2[nod], max(best_val[nod][2], val[nod])); ^ In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from arbvalmax.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template<class _Tp, class _Compare> const _Tp& std::max(const _Tp&, const _Tp&, _Compare) max(const _Tp& __a, const _Tp& __b, _Compare __comp) ^ /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template argument deduction/substitution failed: arbvalmax.cpp:40:67: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') dp2[it] = max(dp2[nod], max(best_val[nod][2], val[nod])); ^ arbvalmax.cpp:42:67: error: no matching function for call to 'max(long long int&, int&)' dp2[it] = max(dp2[nod], max(best_val[nod][1], val[nod])); ^ arbvalmax.cpp:42:67: note: candidates are: In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from arbvalmax.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template<class _Tp> const _Tp& std::max(const _Tp&, const _Tp&) max(const _Tp& __a, const _Tp& __b) ^ /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template argument deduction/substitution failed: arbvalmax.cpp:42:67: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') dp2[it] = max(dp2[nod], max(best_val[nod][1], val[nod])); ^ In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from arbvalmax.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template<class _Tp, class _Compare> const _Tp& std::max(const _Tp&, const _Tp&, _Compare) max(const _Tp& __a, const _Tp& __b, _Compare __comp) ^ /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template argument deduction/substitution failed: arbvalmax.cpp:42:67: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') dp2[it] = max(dp2[nod], max(best_val[nod][1], val[nod])); ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Arbvalmax 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ă.