Cerința
Se dă vectorul de tați al unui arbore cu rădăcină cu n
noduri. Fiecare nod al arborelui are asociată o valoare numerică întreagă. Determinați nodurile p
din arbore pentru care suma valorilor asociate nodurilor din subarborele cu rădăcina în p
este maximă.
Date de intrare
Fișierul de intrare sumsubmax.in
conține pe prima linie numărul de noduri n
. Pe a doua linie se află vectorul de tați al arborelui, valorile fiind separate prin spații. Pe linia a treia se află, în ordine, valorile asociate nodurilor din arbore, separate și ele prin spații.
Date de ieșire
Fișierul de ieșire sumsubmax.out
va conține, în ordine crescătoare, nodurile p
din arbore pentru care suma valorilor asociate nodurilor din subarborele cu rădăcina în p
este maximă, separate printr-un spațiu.
Restricții și precizări
1 ≤ n ≤ 100
- în vectorul de tați rădăcina este marcată cu
0
- valorile asociate nodurilor din arbore sunt numere întregi din intervalul
[-1000,1000]
Exemplu
sumsubmax.in
8 4 3 0 3 2 1 2 1 -3 2 -7 4 0 3 3 1
sumsubmax.out
2 4
Explicație
În subarborii cu rădăcina în 2
și 4
suma valorilor asociate nodurilor este 5
și este maximă.
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema SumSubMax:
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("sumsubmax.in");
ofstream fout("sumsubmax.out");
int n , t[105], v[105] , sum[105];
void dfs(int k)
{
int s = 0;
for(int i = 1 ; i <= n ; ++i)
if(t[i] == k)
{
dfs(i);
s += sum[i];
}
sum[k] = s + v[k];
}
int main()
{
fin >> n;
for(int i = 1 ; i <= n ; i ++)
fin >> t[i];
for(int i = 1 ; i <= n ; i ++)
fin >> v[i];
int r = 0 ;
for(int i = 1 ; i <= n ; i ++)
if(t[i] == 0)
r = i;
dfs(r);
int smax = sum[1];
for(int i = 1 ; i <= n ; ++i)
if(smax < sum[i])
smax = sum[i];
for(int i = 1 ; i <= n ; ++i)
if(smax == sum[i])
fout << i << " ";
return 0;
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #651 SumSubMax
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #651 SumSubMax de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!