博客
关于我
G. Reducing Delivery Cost(思维+最短路)
阅读量:242 次
发布时间:2019-03-01

本文共 1700 字,大约阅读时间需要 5 分钟。


思路:开始看到了路线免费,以为是出了分层最短路板子,看了看发现只让一条路免费。

开始直接考虑暴力,枚举每条边,然后每个点进行dijkstra,最后取最小。复杂度O(n^2klogm);

考虑一下对每个点其实可以先预处理,提前处理好每个点的对应的最短路。O(n^2logm)

考虑免费的边的贡献。

对每一个ki来说,边(a,b)有三种情况。

1.开始不在其最短路路径上,免费后也不在其最短路路径上。

2.开始不在其最短路路径上,免费后在其最短路路径上。

3.开始在其最短路路径上,免费后在其最短路路径上。

对于第一种情况,ki的最短路长度不变,仍然是原来的dis[ki.first][ki.second] (ki.first和ki.second分别代表其起点和终点)

对于第二三种情况,ki的最短路长度可能变化,dis[ki.first][a]+dis[ki.second][b];dis[ki.first][b]+dis[ki.second][a];

那么枚举边,再枚举每个k,求出总和的最小.

总时间复杂度O(mk+n^2logm)

#include
#include
#include
#include
#include
#include
#include
#include
#include
#define debug(a) cout<<#a<<"="<
<
P;///first距离,second编号LL dis[maxn];LL n,m,k,start;struct edge{ LL to,cost;};vector
g[maxn];LL f[maxn][maxn];bool vis[maxn];void dijkstra(){ LL s=start; memset(dis,0x3f,sizeof(dis)); memset(vis,0,sizeof(vis)); dis[s]=0; priority_queue< P, vector

, greater

>que; que.push({0,s}); while(!que.empty()) { P p=que.top();que.pop(); LL v=p.second; if(vis[v]) continue; vis[v]=1; for(LL i=0;i

dis[v]+e.cost) { dis[e.to]=dis[v]+e.cost; que.push({dis[e.to],e.to}); } } } for(LL j=1;j<=n;j++){ f[s][j]=dis[j]; }}int main(void){ cin.tie(0);std::ios::sync_with_stdio(false); cin>>n>>m>>k; vector
>Edge; for(LL i=1;i<=m;i++) { LL u,v,w;cin>>u>>v>>w; g[u].push_back({v,w}); g[v].push_back({u,w}); Edge.push_back({u,v}); } vector
> v; for(LL i=1;i<=k;i++) { LL a,b;cin>>a>>b; v.push_back({a,b}); } for(LL i=1;i<=n;i++) { start=i; dijkstra(); } LL sum=1e18; for(auto i:Edge)///遍历每条边 { LL a=i.first;LL b=i.second; LL ans=0; for(auto j:v)///遍历所有人 { ans+=min( f[j.first][j.second],min(f[j.first][a]+f[j.second][b],f[j.first][b]+f[j.second][a]) ); } sum=min(sum,ans); } cout<
<

 

转载地址:http://twct.baihongyu.com/

你可能感兴趣的文章
nat 网卡间数据包转发_你是不是从来没有了解过光纤网卡,它跟普通网卡有什么区别?...
查看>>
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,解决动态域名解析难题
查看>>
natapp搭建外网服务器
查看>>
NativePHP:使用PHP构建跨平台桌面应用的新框架
查看>>
nativescript(angular2)——ListView组件
查看>>
NativeWindow_01
查看>>
Native方式运行Fabric(非Docker方式)
查看>>
Nature | 电子学“超构器件”, 从零基础到精通,收藏这篇就够了!
查看>>
Nature和Science同时报道,新疆出土四千年前遗骸完成DNA测序,证实并非移民而是土著...
查看>>
Nature封面:只低一毫米,时间也会变慢!叶军团队首次在毫米尺度验证广义相对论...
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
nat打洞原理和实现
查看>>
NAT技术
查看>>
NAT模式/路由模式/全路由模式 (转)
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
NAT的全然分析及其UDP穿透的全然解决方式
查看>>