求助,蒟蒻只对了一个测试点
查看原帖
求助,蒟蒻只对了一个测试点
187094
金色传说楼主2020/7/19 10:12
#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;
}

实在不知道哪里错了

2020/7/19 10:12
加载中...