#1202
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 | #43836682 | Utilizator | |
| Fișier | arbvalmax.cpp | Dimensiune | 3.26 KB |
| Data încărcării | 18 Mai 2023, 21:47 | Scor/rezultat | 70 puncte |
arbvalmax.cpp: In function 'void solve()': arbvalmax.cpp:104:15: warning: unused variable 'c' [-Wunused-variable] for(auto &c:poz) ^ arbvalmax.cpp: At global scope: arbvalmax.cpp:143:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type] main() ^ arbvalmax.cpp: In function 'int main()': arbvalmax.cpp:145:10: warning: variable 'sol' set but not used [-Wunused-but-set-variable] auto sol=[&](bool x) ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0 secunde | OK. | 10 | 10 | ||
| 2 | 0 secunde | OK. | 10 | 10 | ||
| 3 | 0.004 secunde | OK. | 10 | 10 | ||
| 4 | 0.004 secunde | OK. | 10 | 10 | ||
| 5 | 0.048 secunde | OK. | 10 | 10 | ||
| 6 | 0.3 secunde | OK. | 10 | 10 | ||
| 7 | 0.5 secunde | OK. | 10 | 10 | ||
| 8 | Depășit | Limita de timp depășită | 10 | 0 | ||
| 9 | Depășit | Limita de timp depășită | 10 | 0 | ||
| 10 | Depășit | Limita de timp depășită | 10 | 0 | ||
| Punctaj total | 70 | |||||
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ă.