CF449B Jzzhu and Cities 迪杰斯特拉最短路算法
2024-10-08 03:30:58
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条特殊边可能会重复
那其实我们只需要留下来一条最短的就行了
用这个最短的一条去构建最短路
剩下的就直接删掉了
最后只需要用总边数减去剩余的特殊边的数量就行啦!~
最新文章
- sql数据库获取表名称和表列名
- Ibatis 测试出SQL
- 腾讯云CentOS7安装LNMP+wordpress
- iOS 基于UIWebView的应用特点
- js计算2个日期相差的天数,两个日期相差的天数,日期相隔天数
- ubuntu sublime安装及配置
- SpringMVC + Spring 3.2.14 + Hibernate 3.6.10
- Oracle实现主键自增长
- .Net Core 系列:2、ADO.Net 基础
- OC版贪吃蛇
- 命运(经典dp)
- ExecutorService
- import cv2出现“ImportError: DLL load failed: 找不到指定的模块”
- JS获取option的value和text
- 关于js键盘事件的例子
- kod 编辑器下载
- lfs(systemv版本)学习笔记-第4页
- MySQL忘记root密码--不重启mysqd重置root密码
- python 文件保存 出错
- 《MySQL:菜鸟入门系列》
热门文章
- H3C 在接口上应用ACL
- python调用java代码,jpype简单使用
- 2018-11-19-win10-uwp-使用-AppCenter-自动构建
- Total Commander 显示文件包含文件名扩展
- linux 不用 ioctl 的设备控制
- JS(JavaScript)的j进一步了解9(更新中&#183;&#183;&#183;)
- 【Linux】Ubuntu16.04 ftp匿名访问
- 用WPF实现大数据分析,超炫的效果,还带地图
- 老板让阿粉学习 flink 中的 Watermark,现在他出教程了
- $CF908D\ New\ Year\ and\ Arbitrary\ Arrangement$ 期望$dp$