Pagini recente » Cod sursa (job #1402750) | Cod sursa (job #3199590) | Cod sursa (job #2967382) | Cod sursa (job #1221673) | Cod sursa (job #118607)
Cod sursa(job #118607)
#include <stdio.h>
#include <algorithm>
#include <vector>
using namespace std;
#define maxn 16010
#define ll long long
int n;
vector <int> a[maxn];
int f[maxn],g[maxn];
ll c[maxn],d[maxn],v[maxn];
int cmp(int x,int y)
{
return x>y;
}
void DFS(int nod)
{
int i;
d[nod] = f[nod];
for (i=0;i<g[nod];i++)
{
DFS(a[nod][i]);
d[nod] += d[a[nod][i]];
c[nod] += c[a[nod][i]];
}
for (i=0;i<g[nod];i++) v[i]=d[a[nod][i]];
c[nod] += d[nod];
sort(v,v+g[nod],cmp);
for (i=0;i<g[nod];i++) c[nod] += 1LL*i*v[i];
}
int main()
{
freopen("dosare.in","r",stdin);
freopen("dosare.out","w",stdout);
scanf("%d ",&n);
int i,x;
for (i=2;i<=n;i++)
{
scanf("%d ",&x);
a[x].push_back(i);
}
for (i=1;i<=n;i++) scanf("%d ",&f[i]);
for (i=1;i<=n;i++) g[i]=a[i].size();
DFS(1);
printf("%lld\n",c[1]);
return 0;
}