社区讨论

20pts求助

P3371【模板】单源最短路径(弱化版)参与者 3已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lo1usff8
此快照首次捕获于
2023/10/23 03:20
2 年前
此快照最后确认于
2023/11/03 03:50
2 年前
查看原帖
CPP
#include <iostream>
#include <queue>
#include <cstring>
#define int long long
using namespace std;
priority_queue<int,vector<int>,greater<int> >q;
vector<int>vv[100005],vv2[100005];
int n,m,s,u,v,w,mu[100005],em[100005];
signed main()
{
    cin >> n >> m >> s;
    q.push(s);
    for(int i = 1;i <= m;i ++)
    {
        scanf("%lld%lld%lld",&u,&v,&w);
        vv[u].push_back(v);vv2[u].push_back(w);
    }
    memset(em,0x3f,sizeof(em));
    em[s] = 0;
    while(!q.empty())
    {
        w = q.top();
        q.pop();
        if(mu[w] == 1)continue;
        mu[w] = 1;
        for(int i = 0;i < vv[w].size();i ++)
            if(em[vv[w][i]] > em[w] + vv2[w][i] && mu[vv[w][i]] == 0)
            {
                em[vv[w][i]] = em[w] + vv2[w][i];
                q.push(vv[w][i]);
            }
    }
    for(int i = 1;i <= n;i ++)
	{
		if(em[i] > 1e15)cout << "2147483647 ";
		else cout << em[i] << " ";
	}
}

回复

2 条回复,欢迎继续交流。

正在加载回复...