当前位置: 首页 > news >正文

洛谷-P14345 [JOISC 2019] Two Transportations 题解

形式化题意

给定一张 \(N\) 个节点 \(A+B\) 条边的无向连通图,边权是 \(\le 500\) 的正整数。Azer 知道其中 \(A\) 条边,Baijan 知道另外 \(B\) 条。双方最多可以互相发送 \(58000\) 比特信息,需要共同求从 \(0\) 到所有节点的最短路。

Solution

将总通信次数均摊到每个节点,得到 \(58000=29\times2000=(2\times\lceil \log_2500\rceil+\lceil \log_22000\rceil)\times 2000\)

\(N\) 很小,而图很稠密,我们可以考虑 \(O(n^2)\) 的朴素 Dijkstra。每次找当前蓝点中距离最小的点,把它标记为白点,并松弛它的所有出边。

每一轮中,两人只需分别找出本地距离最小的蓝点,通过通信得出全局距离最小的蓝点,然后分别在本地用该点进行松弛即可。

因为边权 \(\le500\),所以每一轮新白点的最短路与上一个白点最短路之差一定 \(\le 500\)。双方互相发送距离增量只需 \(2 \times 9\) 比特。然后距离较小的人需要向另一人发送该点编号,需要 \(11\) 比特。恰好满足限制。

Code

Azer.cpp

#include "Azer.h"
#include <vector>
#define rep(i,a,b) for(int i(a);i<b;++i)
#define rept(i,a,b) for(int i(a);i<=b;++i)
#define eb emplace_back
using namespace std;
namespace{constexpr int MAXN=2005,INF=1e9;int N,u,t,lst,d[MAXN];bool f[MAXN],mk;vector<pair<int,int>> g[MAXN];vector<bool> buf;
}
void FindA(){u=-1;rep(i,0,N) if(!f[i]&&(u==-1||d[i]<d[u])) u=i;if(u==-1) return;t=d[u];rep(i,0,9) SendA((d[u]==INF?511:d[u]-lst)>>i&1);  // 注意特判d[u]=INF的情况
}
void UpdA(){lst=d[u]=t,f[u]=true;for(auto [v,w]:g[u]) d[v]=min(d[v],d[u]+w);
}
void ReceiveA(bool b){buf.eb(b);if(!mk&&buf.size()==9){int x=0;rep(i,0,9) x|=buf[i]<<i;buf.clear();x==511?x=INF:x+=lst;if(t<=x){  // 白点来自Arep(i,0,11) SendA(u>>i&1);UpdA(),FindA();}else t=x,mk=true;}if(mk&&buf.size()==11){mk=false,u=0;rep(i,0,11) u|=buf[i]<<i;buf.clear();UpdA(),FindA();}
}
void InitA(int _N,int A,vector<int> U,vector<int> V,vector<int> C){N=_N;fill(d+1,d+N,INF);rep(i,0,A){g[U[i]].eb(V[i],C[i]);g[V[i]].eb(U[i],C[i]);}FindA();
}
vector<int> Answer(){return vector<int>(d,d+N);
}

Baijan.cpp

#include "Baijan.h"
#include <vector>
#define rep(i,a,b) for(int i(a);i<b;++i)
#define rept(i,a,b) for(int i(a);i<=b;++i)
#define eb emplace_back
using namespace std;
namespace{constexpr int MAXN=2005,INF=1e9;int N,u,t,lst,d[MAXN];bool f[MAXN],mk;vector<pair<int,int>> g[MAXN];vector<bool> buf;
}
void FindB(){u=-1;rep(i,0,N) if(!f[i]&&(u==-1||d[i]<d[u])) u=i;if(u==-1) return;t=d[u];rep(i,0,9) SendB((d[u]==INF?511:d[u]-lst)>>i&1);
}
void UpdB(){lst=d[u]=t,f[u]=true;for(auto [v,w]:g[u]) d[v]=min(d[v],d[u]+w);
}
void ReceiveB(bool b){buf.eb(b);if(!mk&&buf.size()==9){int x=0;rep(i,0,9) x|=buf[i]<<i;buf.clear();x==511?x=INF:x+=lst;if(t<x){  // 白点来自Brep(i,0,11) SendB(u>>i&1);UpdB(),FindB();}else t=x,mk=true;}if(mk&&buf.size()==11){mk=false,u=0;rep(i,0,11) u|=buf[i]<<i;buf.clear();UpdB(),FindB();}
}
void InitB(int _N,int B,vector<int> U,vector<int> V,vector<int> C){N=_N;fill(d+1,d+N,INF);rep(i,0,B){g[U[i]].eb(V[i],C[i]);g[V[i]].eb(U[i],C[i]);}FindB();
}
http://www.jsqmd.com/news/745278/

相关文章:

  • 豆包视频怎么去水印?豆包视频去水印方法全测评,2026 亲测有效 - 科技热点发布
  • Node2Vec参数调优与语义分词对比实践
  • 如何在五分钟内通过Python调用Taotoken接入多个大模型
  • 视频号视频怎么下载保存?2026实测下载方法,视频号视频下载方法全攻略 - 科技热点发布
  • 如何在macOS上获得完美的桌面歌词体验:LyricsX完整指南
  • 低代码≠没代码,Python配置驱动开发全解析,深度拆解Meta/字节内部使用的动态Schema引擎
  • 2026年国内GEO优化服务商选型参考:主流优质GEO优化公司推荐TOP6 - 商业小白条
  • Ultimate SD Upscale深度解析:AI图像分块放大技术的专业实践指南
  • AI驱动全景生成技术:从NeRF到动态场景处理
  • 从零开始设计一个CMOS运算放大器:手把手教你搞定一级运放的关键参数与仿真
  • HoneySelect2 HF Patch:一键解决游戏三大痛点,让你的HS2体验焕然一新 ✨
  • 视频号视频怎么保存到手机?2026实测保存方法,视频号视频如何下载不留水印 - 科技热点发布
  • WarcraftHelper:魔兽争霸3终极兼容性解决方案,免费解锁完整游戏体验
  • 有米星电子商务客服AI流量赋能,深圳打造数字平台赋能智能新技术! - 速递信息
  • 通过审计日志功能追踪APIKey使用情况加强安全管控
  • 深入理解DS18B20:从OneWire时序到温度值转换的完整解析(附蓝桥杯单片机应用)
  • Claude 官方发布 Agent 能力评估模型指南
  • 利用taotoken模型广场在ubuntu开发机上为不同任务选型合适模型
  • 终极图像放大神器:waifu2x-caffe完整使用指南
  • Mor-ris独立研究)发表一个模式匹配算法
  • Java 25 ZGC 2.0调优参数速查表(含JDK 25.0.1 HotFix补丁适配说明)
  • R3nzSkin国服换肤完整指南:免费解锁英雄联盟所有皮肤
  • 体验 Taotoken 官方价折扣活动对个人项目月度开发成本的实际影响
  • 3分钟在Windows上安装安卓应用:APK-Installer终极指南
  • OBS-VST终极指南:如何在OBS中免费使用专业VST插件提升直播音质
  • PhpWebStudy终极指南:5大核心优势解决全栈开发环境管理难题
  • 告别手动Push!高通平台Camera调试文件camxoverridesettings.txt编译集成保姆级教程
  • 告别手工报表:用EasyReport让SQL数据秒变专业报表
  • 英雄联盟国服换肤工具:R3nzSkin技术解析与实战指南
  • Weft:为AI编码智能体设计的专业级设计系统蓝图