#include<bits/stdc++.h>
#define inf 0x7f
using namespace std;
vector<pair<int,int> > gra[100081];
long long d[100081];
void add(int u,int v,int w)
{
gra[u].push_back(make_pair(v,w));
gra[v].push_back(make_pair(u,w));
}
int n,m,s;
bool visit[100001];
void dij()
{
d[s]=0;
priority_queue<pair<int,int> > q;
q.push(make_pair(d[s],s));
int f;
while(!q.empty())
{
f=q.top().second;
q.pop();
visit[f]=true;
if(q.top().first!=d[f]) continue;
int tv,tw;
for(int i=0;i<gra[f].size();i++)
{
tv=gra[f][i].first,tw=gra[f][i].second;
if(d[f]+tw<d[tv])
{
d[tv]=d[f]+tw;
if(visit[tv]==0) q.push(make_pair(d[tv],tv));
}
}
}
}
int main()
{
int u,v,w;
cin>>n>>m>>s;
for(int i=1;i<=m;i++)
{
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);
}
memset(d,inf,sizeof(d));
dij();
for(int i=1;i<=n;i++) cout<<d[i]<<" ";
return 0;
}
实在不知道哪里错了