#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define maxn 1000010
#define INF (1LL<<50)
using namespace std;
typedef long long llg;
int n,a[maxn],ru[maxn],d[maxn],ld;
int head[maxn],next[maxn<<1],to[maxn<<1],tt;
llg f[maxn][2],dp[maxn][2],now,ans;
int getint(){
int w=0;bool q=0;
char c=getchar();
while((c>‘9‘||c<‘0‘)&&c!=‘-‘) c=getchar();
if(c==‘-‘) c=getchar(),q=1;
while(c>=‘0‘&&c<=‘9‘) w=w*10+c-‘0‘,c=getchar();
return q?-w:w;
}
void link(int x,int y){
to[++tt]=y;next[tt]=head[x];head[x]=tt;
to[++tt]=x;next[tt]=head[y];head[y]=tt;
ru[x]++; ru[y]++;
}
void dfs(int u){
while(ru[u]==1){
f[u][1]+=a[u]; int k=0;
for(int i=head[u],v;v=to[i],i;i=next[i])
if(ru[v]>1){
if((--ru[v])==1) k=v;
f[v][0]+=max(f[u][0],f[u][1]);
f[v][1]+=f[u][0];
}
if(k) u=k; else break;
}
}
void work(){
for(int i=1;i<=ld;i++){
dp[i][0]=max(dp[i-1][0],dp[i-1][1]); dp[i][0]+=f[d[i]][0];
dp[i][1]=dp[i-1][0]; dp[i][1]+=f[d[i]][1]+a[d[i]];
}
}
int main(){
File("a");
n=getint();
for(int i=1;i<=n;i++) a[i]=getint(),link(i,getint());
for(int i=1;i<=n;i++) if(ru[i]==1) dfs(i);
for(int i=1;i<=n;i++)
if(ru[i]!=1){
d[ld=1]=i; now=0;
for(int j=1,u;j<=ld;j++){
u=d[j]; ru[u]=1;
for(int k=head[u],v;v=to[k],k;k=next[k])
if(ru[v]!=1){d[++ld]=v;break;}
}
dp[0][0]=0; dp[0][1]=-INF; work();
now=max(now,dp[ld][0]);
dp[0][0]=-INF; dp[0][1]=0; work();
now=max(now,dp[ld][1]);
ans+=now;
}
printf("%lld",ans);
return 0;
}