#include using namespace std; #define int long long #define rep(i,s,n) for(int i = s;i=(s);i--) #define all(v) (v).begin(),(v).end() #define pb push_back #define fi first #define se second #define chmin(a,b) a=min((a),(b)) #define chmax(a,b) a=max((a),(b)) typedef long long ll; typedef pairpint; typedef vectorvint; typedef vectorvpint; typedef pair P1; typedef pair P2; typedef pairPP; static const ll maxLL = (ll)1 << 62; const ll MOD=1000000007; const ll INF=1e18; int dx[]={0,0,1,-1}; int dy[]={-1,1,0,0}; int N,M,K; vector v; struct UF{ vectorpar,sz; void init(int n){ par.resize(n); sz.resize(n); for(int i=0;i>N>>M>>K; rep(i,0,M){ int a,b,c; cin>>a>>b>>c; a--;b--; v.pb(P2(c,pint(a,b))); } int ans=0; UF uf; uf.init(N+1); rep(i,0,K){ int x;cin>>x;x--; uf.unite(v[x].se.fi,v[x].se.se); ans-=v[x].fi; } sort(all(v)); for(auto e:v){ P2 p=e; if(!(uf.same(p.se.fi,p.se.se))){ uf.unite(p.se.fi,p.se.se); }else{ ans+=p.fi; //cout<