最短路 P1629 邮递员送信

传送门

其实这一道题还是比较不错的

这一道题的题意稍微转化一下就是邮递员要到一个节点 然后再返回 求最短路

这我们很显然是可以用dijkstra算法的

我们先按照题目中给的边(单向边) 跑一边最短路

接下来一步我们是要求从各个点出发到S的最短路

乍一看很复杂的样子

其实只需要把整张图的边全部倒过来存储 然后再从起点开始跑一边最短路就可以了!

下面是代码(其实敲起来还是很简单的 练练代码熟练度~)

#include<bits/stdc++.h>
#define pa pair<int,int>
#define maxn 1005
using namespace std;
vector<int> v[maxn],w[maxn];
vector<int> v2[maxn],w2[maxn];
int n,m    ;
int vis[maxn];
int dis[maxn];
void dijkstra(){
    priority_queue<pa,vector<pa> ,greater<pa> > q;
    q.push(make_pair(0,1));
    memset(dis,0x3f,sizeof(dis));
    dis[1]=0;
    while(!q.empty())
    {
        int x=q.top().second;
        q.pop();
        if(vis[x]) continue;
        vis[x]=1;
        for(int i=0;i<v[x].size();i++)
        {
            int y=v[x][i];
            int val=w[x][i];
            if(dis[x]+val<dis[y])
            {
                dis[y]=dis[x]+val;
                q.push(make_pair(dis[y],y));
            }
        }
    }
}
void dijkstra2()
{
    priority_queue<pa,vector<pa>,greater<pa> > q;
    q.push(make_pair(0,1));
    memset(vis,0,sizeof(vis));
    memset(dis,0x3f,sizeof(dis));
    dis[1]=0;
    while(!q.empty())
    {
        int x=q.top().second;
        q.pop();
        if(vis[x]) continue;
        vis[x]=1;
        for(int i=0;i<v2[x].size();i++)
        {
            int y=v2[x][i];
            int val=w2[x][i];
            if(dis[x]+val<dis[y])
            {
                dis[y]=dis[x]+val;
                q.push(make_pair(dis[y],y));
            }
        }
    }
}
int main()
{

    scanf("%d%d",&n,&m);
    for(int i=1,x,y,z;i<=m;i++)
    {
        scanf("%d%d%d",&x,&y,&z);
        v[x].push_back(y);
        w[x].push_back(z);
        v2[y].push_back(x);
        w2[y].push_back(z);
    }
    long long ans=0;
    dijkstra();
    for(int i=2;i<=n;i++)
        ans+=dis[i];
    dijkstra2();
    for(int i=2;i<=n;i++)
        ans+=dis[i];
    printf("%lld",ans);
    return 0;
}

原文地址:https://www.cnblogs.com/akioi/p/12215570.html

时间: 2024-10-12 04:44:22

最短路 P1629 邮递员送信的相关文章

洛谷 P1629 邮递员送信

P1629 邮递员送信 题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员每次只能带一样东西.求送完这N-1样东西并且最终回到邮局最少需要多少时间. 输入输出格式 输入格式: 第一行包括两个整数N和M. 第2到第M+1行,每行三个数字U.V.W,表示从A到B有一条需要W时间的道路. 满足1<=U,V<=N,1<=W<=10000,输入保

[题解]洛咕P1629 邮递员送信

链接 一个邮递员要从一号点到每个点再回来,求最短路 题目说一次只能去一个点,这样就简单了,求每个点最短路 怎么求回来的最短路?每个点跑一次dijkstra?这样会T 只要反向建边,再求点1到各点的最短路不就行了吗?(可以画个图手算一遍) 代码: #include<cstdio> #include<algorithm> #include<cstring> #include<iostream> #include<queue> using namesp

P1629 邮递员送信(未完成)

题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员每次只能带一样东西.求送完这N-1样东西并且最终回到邮局最少需要多少时间. 输入输出格式 输入格式: 第一行包括两个整数N和M. 第2到第M+1行,每行三个数字U.V.W,表示从A到B有一条需要W时间的道路. 满足1<=U,V<=N,1<=W<=10000,输入保证任意两点都能互相到达.

洛谷—— P1629 邮递员送信

https://www.luogu.org/problem/show?pid=1629 题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员每次只能带一样东西.求送完这N-1样东西并且最终回到邮局最少需要多少时间. 输入输出格式 输入格式: 第一行包括两个整数N和M. 第2到第M+1行,每行三个数字U.V.W,表示从A到B有一条需要W时间的道路. 满足

codevs3872 邮递员送信(SPFA)

邮递员送信 时间限制: 1 Sec  内存限制: 64 MB提交: 10  解决: 5[提交][状态][讨论版] 题目描述 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条 道路,通过每条道路需要一定的时间.这个邮递员每次只能带一样东西.求送完这N-1样东西并且最终回到邮局最少需要多少时间. 输入 第一行包括两个整数N和M. 第2到第M+1行,每行三个数字U.V.W,表示从A到B有一条需要W时间的道路

邮递员送信(luogu 1629)题解

[问题描述] 有一个邮递员要送东西,邮局在节点1.他总共要送N-1样东西,其目的地分别是2~N.由于这个城市的交通比较繁忙,因此所有的道路都是单行的,共有M条道路,通过每条道路需要一定的时间.这个邮递员每次只能带一样东西.求送完这N-1样东西并且最终回到邮局最少需要多少时间. [样例输入] 5 10    2 3 5    1 5 5    3 5 6    1 2 8    1 3 8    5 3 4    4 1 8    4 5 3    3 5 6    5 4 2 [样例输出] 83

反向存边(逆图)

#include<iostream> #include<cstdio> #include<cstring> #include<vector> #include<queue> using namespace std; #define max1 1001 #define max2 100001 int n,m,dis[max1],sum=0; vector<int>a[max1],b[max1],c[max1],d[max1]; queu

[USACO07FEB]银牛派对Silver Cow Party

题目描述 寒假到了,N头牛都要去参加一场在编号为X(1≤X≤N)的牛的农场举行的派对(1≤N≤1000),农场之间有M(1≤M≤100000)条有向路,每条路长Ti(1≤Ti≤100). 每头牛参加完派对后都必须回家,无论是去参加派对还是回家,每头牛都会选择最短路径,求这N头牛的最短路径(一个来回)中最长的一条路径长度. 输入输出格式 输入格式: 第一行三个整数N,M, X: 第二行到第M+1行:每行有三个整数Ai,Bi, Ti ,表示有一条从Ai农场到Bi农场的道路,长度为Ti. 输出格式:

【luogu1629】快递员送信 (spfa)

luoguP1629 邮递员送信 是该好好巩固一下QAQ 刷水题使我快乐 论两信竞学生如何讨论一道黄题纠结半个小时 正反各跑一遍spfa 用1次SPFA找各个点到点1的最短路,然后开一个反向图,再用SPFA搜一下点1到反向图各个点的最短路,反向图中点1到各个点的最短路就是普通图中各个点到点1的最短路 1 #include<bits/stdc++.h> 2 using namespace std; 3 const int N=1000+5,inf=1e9; 4 int n,m,ans=0; 5