Fişierul intrare/ieşire:arboras.in, arboras.outSursăRMI 2020 Ziua 2
AutorAndrei Constantinescu, Dan Constantin Spatarel, Tamio-Vesa NakajimaAdăugată deBodo171Bogdan Pop Bodo171
Timp execuţie pe test1.75 secLimită de memorie262144 kbytes
Scorul tăuN/ADificultateN/A

Vezi solutiile trimise | Statistici

Arboras

Magul Roxanne, după nenumărate ore de cercetare a misterelor antice, a decis să meargă la cafenea să se relaxeze. Când a ajuns la vechea cafenea, a văzut pe perete o structură ciudată numită arbore. Formal, un arbore este o colect, i.e. de N vârfuri numerotate cu numere naturale consecutive, unde vârful 0 este rădăcina, şi toate celelalte vârfuri au un părinte unic (vârful v are părintele pv). Deoarece cafeneaua este condusă de magi şi programatori, arborele este desenat cu rădăcina în sus.

Magul, intrigat de această structură, decide să toarne cafea magică într-unul dintre vârfuri. Dacă cafeua este turnată în vârful u, atunci aceasta se revarsă în subarborele cu rădăcina în vârful u. Deoarece este o cafea magică, nu curge la întâmplare ci ocupă cel mai lung lanţ, pe care îl poate ocupa, în subarborele cu rădăcina în vârful u, când trece prin nodul u. Cantitatea de cafea pierdută când curge, este proporţională cu lungimea lanţului pe care cafeaua îl ocupă. Roxanne notează această cantitate cu ru. Reţineţi că muchiile arborelui pot avea lungimi diferite.

Roxanne este interesată de cantitatea de cafea pe care ar putea să o piardă dacă o toarnă în toate vârfurile arborelui, aceasta este suma valorilor ru din toate vârfurile u ale arborelui. Asta nu este greu de calculat iniţial, dar programatorii decid să o provoace şi cresc lungimea anumitor muchii de Q ori. O poţi ajuta pe Roxanne să găsească lungimea totală a tuturor lanţurilor ocupate de cafea, dacă cafeua este turnată în toate vârfurile, iniţial şi după fiecare din cele Q modificări? Atenţie! Are nevoie de răspunsuri modulo 109 + 7.

Date de intrare

În fişierul de intrare arboras.in, prima linie conţine un singur număr întreg N, numărul de vârfuri.
A doua linie conţine N−1 numere întregi: p1, p2, . . . , pN−1, unde pv este părintele nodului v, în timp ce nodul 0 este rădăcina.
A treia linie cont, ine N−1 numere întregi: d1, d2, . . . , dN−1, unde dv este lungimea muchiei dintre vârful v şi pv.
A patra linie conţine Q, numărul de creşteri.
Fiecare din următoarele Q linii conţine câte două numere întregi vi şi addi, reprezentând modificarea i lungimea muchiei dintre vârfurile vi şi pvi creşte cu addi.

Date de ieşire

În fişierul de ieşire arboras.out, tipăriţi Q+1 linii: pe linia i+1 - a afişaţi răspunsul după a i-a modificare. Pe prima linie trebuie să afişaţi răpunsul înainte de orice modificare. Toate răspunsurile trebuie afişate modulo 109 + 7.

Restricţii

  • 1 ≤ N ≤ 100 000
  • 1 ≤ Q ≤ 100 000
  • 1 ≤ di ≤ 100 000 pentru orice 1 ≤ i ≤ N-1
  • 1 ≤ di < i pentru orice 1 ≤ i ≤ N-1
  • 1 ≤ addi ≤ 109 pentru orice 1 ≤ i ≤ Q
  • Pentru 11 puncte: 1 ≤ N ≤ 1 000, 1 ≤ Q ≤ 1 000
  • Pentru alte 13 puncte: Intaltimea arborelui este cel mult 50
  • Pentru alte 31 de puncte di = 100 000 pentru orice 1 ≤ i ≤ N-1, addi = 109 pentru orice 1 ≤ i ≤ Q

Exemplu

arboras.inarboras.out
5
0 0 1 1
0 0 0 0
10
1 2
2 2
3 2
4 2
4 1
3 1
2 1
1 1
4 1000
2 1000
0
2
4
8
10
12
13
14
15
2015
3015
Trebuie sa te autentifici pentru a trimite solutii. Click aici

Cum se trimit solutii?