[POI2013]Morskie opowieści
[POI2013]Morskie opowieści
题目大意:
一个\(n(n\le5000)\)点\(m(m\le5000)\)边无向图,边权均为\(1\),有\(k(k\le10^6)\)个询问。
每次询问给出\((s,t,d)\),要求回答是否存在一条从\(s\)到\(t\)的路径(可以自交),长度为\(d\)。
思路:
我们只需要求出两点间的奇最短路和偶最短路,询问时根据\(k\)的奇偶性,与最短路作比较,超过的部分可以在任意两点间绕。
时间复杂度\(\mathcal O(n^2+q)\),空间复杂度\(\mathcal O(n^2)\)。
#include<queue>
#include<cstdio>
#include<cctype>
#include<vector>
#include<climits>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=5001;
std::vector<int> e[N];
inline void add_edge(const int &u,const int &v) {
e[u].push_back(v);
e[v].push_back(u);
}
bool vis[2][N];
int n,dis[N][2][N];
std::queue<std::pair<bool,int> > q;
inline void bfs(const int &s,int dis[2][N]) {
std::fill(&vis[0][1],&vis[0][n]+1,false);
std::fill(&vis[1][1],&vis[1][n]+1,false);
std::fill(&dis[0][1],&dis[0][n]+1,INT_MAX);
std::fill(&dis[1][1],&dis[1][n]+1,INT_MAX);
dis[0][s]=0;
vis[0][s]=true;
q.push(std::make_pair(0,s));
while(!q.empty()) {
const bool &t=q.front().first;
const int &x=q.front().second;
for(register unsigned i=0;i<e[x].size();i++) {
const int &y=e[x][i];
if(vis[!t][y]) continue;
if(dis[t][x]+1<dis[!t][y]) {
dis[!t][y]=dis[t][x]+1;
vis[!t][y]=true;
q.push(std::make_pair(!t,y));
}
}
q.pop();
}
}
int main() {
n=getint();
const int m=getint(),q=getint();
for(register int i=0;i<m;i++) {
add_edge(getint(),getint());
}
for(register int i=1;i<=n;i++) bfs(i,dis[i]);
for(register int i=0;i<q;i++) {
const int x=getint(),y=getint(),k=getint();
if(x==y&&k%2==0) {
if(e[x].size()) {
puts(dis[x][k&1][y]<=k?"TAK":"NIE");
} else {
puts(k==0?"TAK":"NIE");
}
continue;
}
puts(dis[x][k&1][y]<=k?"TAK":"NIE");
}
return 0;
}
这样在洛谷上是能过的,但是在BZOJ和SZKOpuł上过不了,因为原题的空间限制是128MB。
发现\(dis(i,j)=dis(j,i)\),所以dis数组的内存可以减小一半。
#include<queue>
#include<cstdio>
#include<cctype>
#include<vector>
#include<climits>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=5001;
std::vector<int> e[N];
inline void add_edge(const int &u,const int &v) {
e[u].push_back(v);
e[v].push_back(u);
}
bool vis[2][N];
int n;
std::vector<int> dis[N][2];
std::queue<std::pair<bool,int> > q;
inline int &dist(const int &x,const bool &t,const int &y) {
return dis[std::max(x,y)][t][std::min(x,y)];
}
inline void bfs(const int &s) {
dis[s][0].resize(s+1);
dis[s][1].resize(s+1);
std::fill(&vis[0][1],&vis[0][n]+1,false);
std::fill(&vis[1][1],&vis[1][n]+1,false);
for(register int i=1;i<=n;i++) {
dist(s,0,i)=dist(s,1,i)=INT_MAX;
}
dist(s,0,s)=0;
vis[0][s]=true;
q.push(std::make_pair(0,s));
while(!q.empty()) {
const bool &t=q.front().first;
const int &x=q.front().second;
for(register unsigned i=0;i<e[x].size();i++) {
const int &y=e[x][i];
if(vis[!t][y]) continue;
if(dist(s,t,x)+1<dist(s,!t,y)) {
dist(s,!t,y)=dist(s,t,x)+1;
vis[!t][y]=true;
q.push(std::make_pair(!t,y));
}
}
q.pop();
}
}
int main() {
n=getint();
const int m=getint(),q=getint();
for(register int i=0;i<m;i++) {
add_edge(getint(),getint());
}
for(register int i=n;i>=1;i--) bfs(i);
for(register int i=0;i<q;i++) {
const int x=getint(),y=getint(),k=getint();
if(x==y&&k%2==0) {
if(e[x].size()) {
puts(dist(x,0,y)<=k?"TAK":"NIE");
} else {
puts(k==0?"TAK":"NIE");
}
continue;
}
puts(dist(x,k&1,y)<=k?"TAK":"NIE");
}
return 0;
}
于是在SZKOpuł上卡过去了,但是在BZOJ被卡T了。
题解上的做法是将询问离线后,按照\(x\)排序,每次如果遇到新的\(x\)重新BFS即可。
时间复杂度\(\mathcal O(n^2+q\log q)\),空间复杂度\(\mathcal O(n+q)\)。
[POI2013]Morskie opowieści的更多相关文章
- Travis CI用来持续集成你的项目
这里持续集成基于GitHub搭建的博客为项目 工具: zqz@ubuntu:~$ node --version v4.2.6 zqz@ubuntu:~$ git --version git versi ...
- CI Weekly #10 | 2017 DevOps 趋势预测
2016 年的最后几个工作日,我们对 flow.ci Android & iOS 项目做了一些优化与修复: iOS 镜像 cocoapods 版本更新: fir iOS上传插件时间问题修复: ...
- CI Weekly #9 | 揭秘阿里 Docker 化实践之路
2017年悄然而至,对 flow.ci 你有什么新的期待呢?新的一年,flow.ci会越来越强大好用,希望继续得到你的支持与反馈.最近,我们做了如下的「功能优化」与「问题修复」,看看有没有你想要的: ...
- CI Weekly #8 | CI/CD 技能进阶路线
在使用 flow.ci 进行持续集成的过程中,也许你会遇到一些小麻烦.最近我们整理了一些常见问题在 flow.ci 文档之 FAQ,希望对你有用.如果你遇到其他问题,也可以通过「在线消息」或去 Git ...
- CI Weekly #7 | Instgram/Quora 等大公司如何做持续部署?
终于,你们期待的 flow.ci iOS 项目持续集成 开始公测了.在这几个工作日, flow.ci 做了些许「功能优化」与「问题修复」,性能和体验都在持续优化中.比如: iOS 快速入门文档更新: ...
- CI Weekly #6 | 再谈 Docker / CI / CD 实践经验
CI Weekly 围绕『 软件工程效率提升』 进行一系列技术内容分享,包括国内外持续集成.持续交付,持续部署.自动化测试. DevOps 等实践教程.工具与资源,以及一些工程师文化相关的程序员 Ti ...
- CI Weekly #5 | 微服务架构下的持续部署与交付
CI Weekly 围绕『 软件工程效率提升』 进行一系列技术内容分享,包括国内外持续集成.持续交付,持续部署.自动化测试. DevOps 等实践教程.工具与资源,以及一些工程师文化相关的程序员 Ti ...
- php使用CI发送qq和163邮件
1.需求 发送邮件 2.介绍 使用CI框架的email类库发送邮件,这里演示QQ和163 3.163使用教程 a.先去163邮件开启smtp邮件. b.在CI的控制器里写下面的代码 $this-> ...
- 【补充】Gitlab 部署 CI 持续集成
上一篇:<劈荆斩棘:Gitlab 部署 CI 持续集成> 上一篇所配置的.gitlab-ci.yml: stages: - build - test before_script: - ec ...
随机推荐
- Dubbo学习笔记11:使用Dubbo中需要注意的一些事情
指定方法异步调用 前面我们讲解了通过设置ReferenceConfig的setAsync()方法来让整个接口里的所有方法变为异步调用,那么如何指定某些方法为异步调用呢?下面讲解下如何正确地设置默写方法 ...
- bzoj千题计划291:bzoj3640: JC的小苹果
http://www.lydsy.com/JudgeOnline/problem.php?id=3640 dp[i][j] 表示i滴血到达j的概率 dp[i][j] = Σ dp[i+val[i]][ ...
- Spring RedisTemplate操作-String操作(2)
@Autowired @Resource(name="redisTemplate") private RedisTemplate<String, String> rt; ...
- 你真的理解js的赋值语句么
之前谢亮兄和我一起讨论的一个问题: var a = {}; a.x = a = 3; a 的值是什么. 其实当执行赋值语句的时候,js 的 = 左侧不是原始变量地址,而是一个新值.怎么理解这句话呢? ...
- ASP.NET实现二维码(QRCode)的创建和读取
一.项目引用QRCode的DLL文件(ThoughtWorks.QRCode.dll) 二.ASPX页面(两个jquery的js文件请自行去官网下载): [html] <html xm ...
- Raid 磁盘阵列
raid 原理与区别 raid0至少2块硬盘.吞吐量大,性能好,同时读写,但损坏一个就完蛋 raid1至少2块硬盘.相当镜像,一个存储,一个备份.安全性比较高.但是性能比0弱 raid5至少3块硬盘. ...
- os_mudule_docs
pydoc os Help on module os: NAME os - OS routines for Mac, NT, or Posix depending on what system we' ...
- 简单解读linux的/proc下的statm、maps、memmap 内存信息文件分析【转】
转自:https://blog.csdn.net/sctq8888/article/details/7398776 转载自:http://hi.baidu.com/deep_pro/blog/item ...
- pymongo创建索引
from database import db db_list = ["table1", "table2", "table3", " ...
- (转)substring和substr以及slice和splice的用法和区别
转载地址:https://www.cnblogs.com/echolun/p/7646025.html 那么就由一道笔试题引入吧,已知有字符串a=”get-element-by-id”,写一个func ...