「赛后补题」Meeting(HDU-5521)
题意
A,B两个人分别在1和n区。每个区有若干点(区之间的点可以重复,各个区内点间的距离一致),给出区之间有联系的图以及到达所需时间。求两个人见面最短时间以及在哪个区碰面(可有多个)
分析
隐式图搜索。但是注意一点:当我们搜索过一个区之后,这个区的最短路一定是被更新完成的,最短的(只要没有负权边)。因此,我们应当对已经访问过的点加一个标记,即可极大的剪枝,加快对隐式图的Dijkstra。
另一种做法
对于每个区定义一个新的虚拟点,区中的每个点到这点的距离是给定的\(t_i\)(不去生成一个完全图)。这样求最短路后距离除以二即可。
这样的做法可能在网络流中会比较有用,值得注意。
代码
注意行末空格,会让你丢一次PE。
#include <iostream>
#include <cstring>
#include <algorithm>
#include <string>
#include <vector>
#include <set>
#include <unordered_map>
#include <queue>
#define rep(i,a,b) for(repType i=(a);i<=(b);++i)
#define per(i,a,b) for(repType i=(a);i>=(b);--i)
#define fi first
#define ZERO(x) memset(x,0,sizeof(x))
#define se second
#define PB emplace_back
#define MP make_pair
using namespace std;
typedef long long ll;
typedef int repType;
const int MAXN=2e5+5;
vector<int> ma[1000005];
vector<int> gra[MAXN];
ll cost[1000005];
ll dist[MAXN];
ll distb[MAXN],mindist,inf;
bool vis[1000005];
void dijkstra(int b, int n)
{
ZERO(vis);
memset(dist,0x3f,sizeof(dist));
inf=dist[0];
dist[b]=0;
typedef pair<ll,int> P;
priority_queue<P, vector<P>, greater<P> > pq;
pq.push(MP(0,b));
while(!pq.empty())
{
P now=pq.top();
pq.pop();
if(dist[now.se]<now.fi) continue;
/*
printf("Point %d belongs to set: ", now.se);
rep(i, 0, int(ma[now.se].size())-1)
{
cout<<ma[now.se][i]<<" ";
}
cout<<endl;
*/
rep(i, 0, int(ma[now.se].size())-1) //分别属于哪些集合
{
if(!vis[ma[now.se][i]]) // Important here!
vis[ma[now.se][i]]=true;
else continue;
/*
printf(" Set %d has pnts:", ma[now.se][i]);
rep(j,0,int(gra[ma[now.se][i]].size())-1)
printf("%d ",gra[ma[now.se][i]][j]);
cout<<endl;
*/
rep(j, 0, int(gra[ma[now.se][i]].size())-1) //集合分别有哪些点
{
int v=gra[ma[now.se][i]][j];
ll w=cost[ma[now.se][i]]; // 点是啥
if(dist[v]>dist[now.se]+w)
{
dist[v]=dist[now.se]+w;
//pre[now.se]=ma[now.se][i];
pq.push(MP(dist[v],v));
}
}
}
}
}
int main()
{
int T; scanf("%d",&T);
rep(kase, 1, T)
{
int n,m; scanf("%d%d", &n,&m);
rep(i,1,n) ma[i].clear();
rep(i,1,m) gra[i].clear();
rep(i,1,m)
{
int s; scanf("%lld%d", &cost[i], &s);
rep(j,1,s)
{
int tmp; scanf("%d",&tmp);
ma[tmp].PB(i); // 元素分别属于第几块
gra[i].PB(tmp); // 第几块 哪些元素
}
}
dijkstra(1,n);
memcpy(distb,dist,sizeof(dist));
dijkstra(n,n);
mindist=inf;
vector<int> pnt;
rep(i,1,n)
{
ll tmp=max(distb[i],dist[i]);
if(tmp==inf) continue;
if(tmp<mindist)
{
mindist=tmp;
pnt.clear(); pnt.PB(i);
}
else if(tmp==mindist)
{
pnt.PB(i);
}
}
printf("Case #%d: ",kase);
if(pnt.size()==0)
{
printf("Evil John\n");
}
else
{
printf("%lld\n",mindist);
rep(i,0,int(pnt.size())-1)
{
printf("%d",pnt[i]);
printf("%s",i==int(pnt.size())-1?"\n":" ");
}
}
}
return 0;
}
「赛后补题」Meeting(HDU-5521)的更多相关文章
- 「赛后补题」HBCPC2018题目代码与思路简析
这次比赛(2018年第二届河北省大学生程序设计竞赛)虽然没有打,但是题目还是要写的.未完成的题目(还差比较硬核的四题)和思路分析会陆续更新完. Problem A 2011 Mex Query /* ...
- 2018 HDU多校第四场赛后补题
2018 HDU多校第四场赛后补题 自己学校出的毒瘤场..吃枣药丸 hdu中的题号是6332 - 6343. K. Expression in Memories 题意: 判断一个简化版的算术表达式是否 ...
- 2018 HDU多校第三场赛后补题
2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...
- LOJ6003 - 「网络流 24 题」魔术球
原题链接 Description 假设有根柱子,现要按下述规则在这根柱子中依次放入编号为的球. 每次只能在某根柱子的最上面放球. 在同一根柱子中,任何2个相邻球的编号之和为完全平方数. 试设计一个算法 ...
- LOJ6002 - 「网络流 24 题」最小路径覆盖
原题链接 Description 求一个DAG的最小路径覆盖,并输出一种方案. Solution 模板题啦~ Code //「网络流 24 题」最小路径覆盖 #include <cstdio&g ...
- LOJ6001 - 「网络流 24 题」太空飞行计划
原题链接 Description 有个实验和个仪器,做实验有报酬买仪器有花费.每个实验都需要一些仪器,求最大净收益(实验报酬仪器花费),并输出一组方案. Solution 实验向所需仪器连边,实验的点 ...
- LOJ6000 - 「网络流 24 题」搭配飞行员
原题链接 题意简述 求二分图的最大匹配. 题解 这里写的是匈牙利算法. 表示节点的当前匹配. 为真表示在这一轮匹配中,无法给节点一个新的匹配.所以如果为真就不用再dfs它了,直接continue就好. ...
- LibreOJ #6014. 「网络流 24 题」最长 k 可重区间集
#6014. 「网络流 24 题」最长 k 可重区间集 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据 ...
- Libre 6013 「网络流 24 题」负载平衡 (网络流,最小费用最大流)
Libre 6013 「网络流 24 题」负载平衡 (网络流,最小费用最大流) Description G 公司有n 个沿铁路运输线环形排列的仓库,每个仓库存储的货物数量不等.如何用最少搬运量可以使n ...
随机推荐
- 使用QT开发GoogleMap瓦片显示和下载工具
之前做项目的时候经常遇到需要大量地图背景数据,然后没有数据被逼着去Google上下载瓦片数据在拼接成整张影像的工作,其实遥感影像晚上有很多可以下载到的,但是大部分是作为研究用的,作为GIS的背景图或者 ...
- mongo删除、添加分片
MongoDB 分片的原理.搭建.应用 一.概念: 分片(sharding)是指将数据库拆分,将其分散在不同的机器上的过程.将数据分散到不同的机器上,不需要功能强大的服务器就可以存储更多的数据和处 ...
- 【数据结构】浅谈倍增求LCA
思路 运用树上倍增法可以高效率地求出两点x,y的公共祖先LCA 我们设f[x][k]表示x的2k辈祖先 f[x][0]为x的父节点 因为从x向根节点走2k 可以看成从x走2k-1步 再走2k-1步 所 ...
- stylus(css预编译器)
推荐去张鑫旭大神这里详细了解:http://www.zhangxinxu.com/jq/stylus/ 安装 npm install -g stylus 自动编译 $ stylus -w demo.s ...
- 课时10.第一个HTML网页(掌握)
网页的固定格式 编写网页和写信一样都有一套规范和要求,这套规范和要求中规定了写信的固定格式 写信基本结构 亲爱的xx: 你好! 我.................. ...... 此致 敬礼! xx ...
- Unity 游戏框架搭建 (二十一) 使用对象池时的一些细节
上篇文章使用SafeObjectPool实现了一个简单的Msg类.代码如下: class Msg : IPoolAble,IPoolType { #region IPoolAble 实现 public ...
- Unity 游戏框架搭建 (十七) 静态扩展GameObject实现链式编程
本篇本来是作为原来 优雅的QChain的第一篇的内容,但是QChain流产了,所以收录到了游戏框架搭建系列.本篇介绍如何实现GameObject的链式编程. 链式编程的实现技术之一是C#的静态扩展.静 ...
- SpringMVC——笔记
使用 @RequestMapping 映射请求 Spring MVC 使用@RequestMapping 注解为控制器指定可以处理那些URL请求. 在控制器的类定义及方法定义处都可以标注 @Reque ...
- MYSQL 8.0.11 安装过程及 Navicat 链接时遇到的问题
参考博客:https://blog.csdn.net/WinstonLau/article/details/78666423 我的系统和软件版本是这样的: 系统环境:win7.64位 MySQL版本: ...
- JavaSE环境下的shiro(源自腾讯课堂)
Shiro作用: 认证(登录).授权(鉴权).加密(用户名/密码加密).会话管理(session).Web集成.缓存 apache官网可以下载 图一 图二 图三 图一 .二是配置文件内容,对于图三的: ...