#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
using namespace std;
const int maxn=5e5+10;
long long n,root,fa[maxn],dp[maxn],tot[maxn],maxt[maxn],ans;
long long aa;char cc;
long long read() {
aa=0;cc=getchar();
while(cc<‘0‘||cc>‘9‘) cc=getchar();
while(cc>=‘0‘&&cc<=‘9‘) aa=aa*10+cc-‘0‘,cc=getchar();
return aa;
}
long long fir[maxn],nxt[2*maxn],to[2*maxn],val[2*maxn],e=0;
void add(long long x,long long y,long long v){
to[++e]=y;nxt[e]=fir[x];fir[x]=e;val[e]=v;
to[++e]=x;nxt[e]=fir[y];fir[y]=e;val[e]=v;
}
void dfs1(long long pos,long long f,long long t){
fa[pos]=f;maxt[pos]=t;
for(int y=fir[pos];y;y=nxt[y]) {
if(to[y]==fa[pos]) continue;
dfs1(to[y],pos,t+val[y]);
maxt[pos]=max(maxt[pos],maxt[to[y]]);
dp[pos]+=maxt[to[y]];
tot[pos]++;
}
ans+=tot[pos]*maxt[pos]-dp[pos];
}
int main() {
n=read();root=read();
long long x,y,v;
for(int i=1;i<n;++i) {
x=read();y=read();v=read();
add(x,y,v);
}
dfs1(root,0,0);
printf("%lld",ans);
return 0;
}