Fişierul intrare/ieşire: | arboras.in, arboras.out | Sursă | RMI 2020 Ziua 2 |
Autor | Andrei Constantinescu, Dan Constantin Spatarel, Tamio-Vesa Nakajima | Adăugată de | |
Timp execuţie pe test | 1.75 sec | Limită de memorie | 262144 kbytes |
Scorul tău | N/A | Dificultate | N/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.in | arboras.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 |