社区讨论

36pts求调

P4779【模板】单源最短路径(标准版)参与者 3已保存回复 3

讨论操作

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

当前回复
3 条
当前快照
1 份
快照标识符
@mhjtbdhk
此快照首次捕获于
2025/11/04 08:10
4 个月前
此快照最后确认于
2025/11/04 08:10
4 个月前
查看原帖

前4个点WA,后两个点AC求调

代码:

CPP
#include<cstdio>
#include<queue>
#include<vector>
#include<algorithm>
#define ede first
#define dis second
using namespace std;
int n,m,s;
int u,v,w;
int dis[100025]; bool vis[100025];
int main(){
    scanf("%d %d %d",&n,&m,&s);
    vector<vector<pair<int,int>>>g(n+1);
    for(int i=1;i<=m;i++){
        scanf("%d %d %d",&u,&v,&w);
        g[u].push_back(make_pair(v,w));
        // printf("%d %d %d\n",u,g[u][(int)(g[u].size())-1].ede,g[u][(int)(g[u].size())-1].dis);
    }
    for(int i=1;i<=n;i++)dis[i]=2e9;
    dis[s]=0;
    priority_queue<pair<int,int>,vector<pair<int,int>>,greater<pair<int,int>>>sq;
    sq.push(make_pair(s,0));
    while(!sq.empty()){
        v=sq.top().ede;
        w=sq.top().dis;
        sq.pop();
        if(vis[v])continue;
        vis[v]=true;
        for(int i=0;i<(int)(g[v].size());i++){
        	// printf("%d %d %d\n",v,g[v][i].ede,dis[g[v][i].ede]);
            if(dis[v]+g[v][i].dis<dis[g[v][i].ede]){
                dis[g[v][i].ede]=dis[v]+g[v][i].dis;
                sq.push(make_pair(g[v][i].ede,dis[g[v][i].ede]));
            }
        }
    }
    for(int i=1;i<=n;i++)printf("%d ",dis[i]);
    return 0;
}

回复

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

正在加载回复...