题意:
data:image/s3,"s3://crabby-images/fc7fe/fc7fe6534849ffde8fcebb04f4f15196ed56b052" alt=""
data:image/s3,"s3://crabby-images/f53a8/f53a83b730156fbc1cdf0ff4dd97c47a6957d570" alt=""
思路:
https://ac.nowcoder.com/discuss/151522?type=101&order=0&pos=1&page=0&channel=666&source_id=discuss_tag
data:image/s3,"s3://crabby-images/0d478/0d47835230f7bae0876c034a5abf9b287b34d3de" alt=""
data:image/s3,"s3://crabby-images/e281c/e281ca079c6d1ccdecc2c0ea6c9beb7eb74dd9d7" alt=""
data:image/s3,"s3://crabby-images/87ea7/87ea706ee6fc998f04347e20cb78106c31c66f14" alt=""
data:image/s3,"s3://crabby-images/5c37e/5c37e99bf80b4a3bbc9a975db53efa3806107d63" alt=""%E7%9A%84%E8%BE%B9%E6%9D%83%E8%B5%8B%E4%B8%BAdist%5Bu%5D%20-%20dist%5Bv%5D%20%2B%20w(w%E6%98%AF%E5%8E%9F%E6%9D%A5%E7%9A%84%E8%BE%B9%E6%9D%83)&preview=true)
data:image/s3,"s3://crabby-images/2595b/2595b17c71f92e3f3a9bd5cc7bf993ee0b678b94" alt=""
data:image/s3,"s3://crabby-images/740d9/740d90213b3d01c57aff9a9e4373b8171dbb479f" alt=""%E5%BA%94%E6%BB%A1%E8%B6%B3%E4%B8%89%E8%A7%92%E5%BD%A2%E4%B8%8D%E7%AD%89%E5%BC%8Fdist%5Bu%5D%2Bw%20%3E%3D%20dist%5Bv%5D%2C%E7%A7%BB%E9%A1%B9%E5%8F%AF%E5%BE%97&preview=true)
data:image/s3,"s3://crabby-images/78123/781239c4ccda628b9a014b4a9504c536137e488d" alt=""
data:image/s3,"s3://crabby-images/09e5c/09e5ce020da95f61a63bd727ccc3e82449c12913" alt=""
data:image/s3,"s3://crabby-images/955ef/955ef1eb633bdb1714bcc79eece236d69d642898" alt=""
data:image/s3,"s3://crabby-images/b47ec/b47ec18685e01aa494696ddbeded9880aea0b638" alt=""%20%3D%20w(u%2Cx_1)%20%2B%20w(x_1%2Cx_2)%20%2B%20w(x_2%2Cx_3)%20%2B%20....w(x_m%2Cv)&preview=true)
data:image/s3,"s3://crabby-images/a21d7/a21d71e94fbe0908aa22a6efc8afd1e33afbdb60" alt=""%20%2B%20dist%5Bu%5D%20-%20dist%5Bx_1%5D%20%2B%20w(x_1%2Cx_2)%20%2B%20dist%5Bx_1%5D%20-%20dist%5Bx_2%5D%2B....%2Bw(x_m%2Cv)%2Bdist%5Bx_m%5D-dist%5Bv%5D&preview=true)
data:image/s3,"s3://crabby-images/f04a3/f04a36319ec23c7ab48b598773357637603ac437" alt=""
data:image/s3,"s3://crabby-images/0c4ac/0c4ac04ab69ea075d1920b18ec50fbee0bb32a7a" alt=""%20%2B%20w(x_1%2Cx_2)%20%2B%20w(x_2%2Cx_3)%20%2B%20....w(x_m%2Cv)%20%2B%20dist%5Bu%5D%20-%20dist%5Bv%5D&preview=true)
data:image/s3,"s3://crabby-images/53397/533971d537cfabb7ef5bc293f0ec5216e7488df7" alt=""
data:image/s3,"s3://crabby-images/cae52/cae525b4c864fe55db0da33b7b2794c485f524ee" alt=""
#include <cstdio>
#include <cstring>
#include <queue>
#include <iostream>
using namespace std;
const int M = 1e6 + 10;
const int N = 1e3 + 10;
typedef long long ll;
const ll inf = 1e18;
struct Edge{
int u,to,w,nex;
}e[M];
int head[N],idx;
int n,m;
void add_edge(int u,int v,int w){
e[idx].u = u;
e[idx].to = v;
e[idx].w = w;
e[idx].nex = head[u];
head[u] = idx++;
}
ll dist[N];
bool in[N];
void spfa(int S){
for(int i = 0;i <= n;i++){
dist[i] = inf,in[i] = 0;
}
queue<int> q;
dist[S] = 0;
q.push(S);
while(q.size()){
int u = q.front();q.pop();
in[u] = 0;
for(int i = head[u];~i;i = e[i].nex){
int v = e[i].to,w = e[i].w;
if(dist[v] > dist[u] + w){
dist[v] = dist[u] + w;
if(!in[v]){
q.push(v);
in[v] = 1;
}
}
}
}
}
int main(){
memset(head,-1,sizeof(head));
scanf("%d%d",&n,&m);
for(int i = 1,u,v,w;i <= m;i++){
scanf("%d%d%d",&u,&v,&w);
add_edge(u,v,w);
}
for(int i = 1;i <= n;i++) add_edge(0,i,0);
spfa(0);
for(int i = 0,u,v,w;i < m;i++){
u = e[i].u,v = e[i].to,w = e[i].w;
printf("%d %d %lld\n",u,v,dist[u] - dist[v] + w);
}
return 0;
}