CF449B Jzzhu and Cities

其实这一道题并不是很难,只是一个最短路而已,请继续看我的题解吧~(^▽^)

AC代码:

#include<bits/stdc++.h>
#define maxn 3000005
#define pa pair<long long,long long>
#define inf 1000000000000000000ll
using namespace std;
long long n,m,k;
struct edge{
long long val,to;
};
bool vis[maxn];
long long dis[maxn],mark[maxn];
priority_queue<pa,vector<pa>,greater<pa> > q;
vector<edge> e[maxn*3];
long long ans;
void dijkstra()
{
memset(vis,0,sizeof(vis));
dis[1]=0;
q.push(make_pair(0,1));
while(!q.empty()){
int x=q.top().second;
q.pop();
if(vis[x])
continue;
vis[x]=1;
for(int i=0;i<e[x].size();i++){
int y=e[x][i].to;
if(dis[x]+e[x][i].val<=dis[y]){
if(mark[y]){
mark[y]=0;
}
if(dis[x]+e[x][i].val<dis[y]){
dis[y]=dis[x]+e[x][i].val;
q.push(make_pair(dis[y],y));
}
} }
}
}
void addedge(long long x,long long y,long long v){
edge tmp;
tmp.to=y;
tmp.val=v;
e[x].push_back(tmp);
}
int main()
{
scanf("%lld%lld%lld",&n,&m,&k);
for(int i=1;i<=n;i++)
dis[i]=inf;
for(int i=1;i<=m;i++){
long long x,y,z;
scanf("%lld%lld%lld",&x,&y,&z);
addedge(x,y,z);
addedge(y,x,z);
}
for(int i=1;i<=k;i++){
long long y,z;
scanf("%lld%lld",&y,&z);
if(dis[y]>z)
{
dis[y]=z;
q.push(make_pair(z,y));
mark[y]=1;
}
}
dijkstra();
for(int i=1;i<=n;i++)
ans+=mark[i];
printf("%lld\n",k-ans); }

详解

那么我们来简化一下题目的含义
就是说有n个城市
1号城市是起点(树的根)
有m条普通边
有k条特殊边
问最多能删掉多少条边,能使最短路径不变

那么我们就可以先把n+k条边跑一遍dijkstra
然后就求出来了每个城市之间的最短路
在跑最短路的过程中判断这k条特殊边是否去掉后不影响最短路

但是这个题还有一个很坑人的bug
就像样例2中的一样,那k条特殊边可能会重复
那其实我们只需要留下来一条最短的就行了
用这个最短的一条去构建最短路
剩下的就直接删掉了
最后只需要用总边数减去剩余的特殊边的数量就行啦!~

最新文章

  1. sql数据库获取表名称和表列名
  2. Ibatis 测试出SQL
  3. 腾讯云CentOS7安装LNMP+wordpress
  4. iOS 基于UIWebView的应用特点
  5. js计算2个日期相差的天数,两个日期相差的天数,日期相隔天数
  6. ubuntu sublime安装及配置
  7. SpringMVC + Spring 3.2.14 + Hibernate 3.6.10
  8. Oracle实现主键自增长
  9. .Net Core 系列:2、ADO.Net 基础
  10. OC版贪吃蛇
  11. 命运(经典dp)
  12. ExecutorService
  13. import cv2出现“ImportError: DLL load failed: 找不到指定的模块”
  14. JS获取option的value和text
  15. 关于js键盘事件的例子
  16. kod 编辑器下载
  17. lfs(systemv版本)学习笔记-第4页
  18. MySQL忘记root密码--不重启mysqd重置root密码
  19. python 文件保存 出错
  20. 《MySQL:菜鸟入门系列》

热门文章

  1. H3C 在接口上应用ACL
  2. python调用java代码,jpype简单使用
  3. 2018-11-19-win10-uwp-使用-AppCenter-自动构建
  4. Total Commander 显示文件包含文件名扩展
  5. linux 不用 ioctl 的设备控制
  6. JS(JavaScript)的j进一步了解9(更新中&#183;&#183;&#183;)
  7. 【Linux】Ubuntu16.04 ftp匿名访问
  8. 用WPF实现大数据分析,超炫的效果,还带地图
  9. 老板让阿粉学习 flink 中的 Watermark,现在他出教程了
  10. $CF908D\ New\ Year\ and\ Arbitrary\ Arrangement$ 期望$dp$