bzoj2657: [Zjoi2012]旅游(journey)
求树的直径 真是太神辣
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<iostream> using namespace std; template<typename Q> Q &read(Q &x) {
static char c, f;
for(f = ; c = getchar(), !isdigit(c); ) if(c == '-') f = ;
for(x = ; isdigit(c); c = getchar()) x = x * + c - '';
if(f) x = -x; return x;
}
template<typename Q> Q read() {
static Q x; read(x); return x;
} const int N();
int n; bool neighbor(int a, int b) {
return abs(a - b) == || abs(a - b) == n - ;
} #include<map>
map<pair<int, int>, int> mp;
int ID(int u, int v) {
if(u > v) swap(u, v);
if(mp.count(make_pair(u, v))) return mp[make_pair(u, v)];
return mp[make_pair(u, v)] = mp.size();
} int no[N]; #include<vector>
vector<int> G[N]; void AddEdge(int u, int v) {
G[u].push_back(v);
G[v].push_back(u);
} int q[N], ql, qr, dep[N]; void BFS(int s) {
ql = qr = ;
memset(dep, , sizeof dep);
q[qr++] = s, dep[s] = ;
while(ql < qr) {
int u = q[ql++];
for(unsigned i = ; i < G[u].size(); i++) {
int v = G[u][i];
if(!dep[v]) {
q[qr++] = v;
dep[v] = dep[u] + ;
}
}
}
} int main() {
#ifdef DEBUG
freopen("in.txt", "r", stdin);
freopen("out.txt", "w", stdout);
#endif scanf("%d", &n);
for(int i = ; i <= n - ; i++) {
int a[];
for(int j = ; j < ; j++) scanf("%d", a + j);
a[] = a[];
for(int j = ; j < ; j++) {
if(!neighbor(a[j], a[j+])) {
int id = ID(a[j], a[j+]);
if(no[id]) AddEdge(no[id], i);
else no[id] = i;
}
}
} BFS(), BFS(q[qr - ]);
printf("%d\n", dep[q[qr - ]]); return ;
}
bzoj2657: [Zjoi2012]旅游(journey)的更多相关文章
- BZOJ2657 [Zjoi2012]旅游(journey)  【树的直径】
		
题目 到了难得的暑假,为了庆祝小白在数学考试中取得的优异成绩,小蓝决定带小白出去旅游~~ 经过一番抉择,两人决定将T国作为他们的目的地.T国的国土可以用一个凸N边形来表示,N个顶点表示N个入境/出境口 ...
 - BZOJ2657: [Zjoi2012]旅游(journey) (树形DP)
		
题意:一个三角划分的凸多边形 画一条对角线 穿过最多的三角形 题解:把每一个三角形看作一个点 如果某条边是两个三角形的公共边 那么就把这两个三角形连边 然后问题就转化为求树上的最长链了 就当求个直径就 ...
 - [bzoj2657][Zjoi2012]旅游 journey_ 对偶图_树形dp
		
旅游 bzoj-2657 Zjoi-2012 题目大意:题目链接 注释:$1\le K\le 2\cdot 10^5$. 想法:这题... 感觉和上一个题的提示有些类似,就是题目生怕你不知道这是一道对 ...
 - 【BZOJ】2657: [Zjoi2012]旅游(journey)(树的直径)
		
题目 传送门:QWQ 分析 在任意两个不相邻的点连一条线,求这条线能穿过几个三角形. 建图比较讲究(详见代码) 求树的直径. 代码 #include <bits/stdc++.h> usi ...
 - [洛谷P2610] [ZJOI2012]旅游
		
洛谷题目链接:[ZJOI2012]旅游 题目描述 到了难得的暑假,为了庆祝小白在数学考试中取得的优异成绩,小蓝决定带小白出去旅游~~ 经过一番抉择,两人决定将T国作为他们的目的地.T国的国土可以用一个 ...
 - [ZJOI2012]旅游(树的直径)
		
[ZJOI2012]旅游 题目描述 到了难得的暑假,为了庆祝小白在数学考试中取得的优异成绩,小蓝决定带小白出去旅游~~ 经过一番抉择,两人决定将T国作为他们的目的地.T国的国土可以用一个凸N边形来表示 ...
 - BZOJ2657:[ZJOI2012]旅游——题解
		
http://www.lydsy.com/JudgeOnline/problem.php?id=2657 https://www.luogu.org/problemnew/show/P2610 到了难 ...
 - P2610 [ZJOI2012]旅游
		
题目描述 到了难得的暑假,为了庆祝小白在数学考试中取得的优异成绩,小蓝决定带小白出去旅游~~ 经过一番抉择,两人决定将T国作为他们的目的地.T国的国土可以用一个凸N边形来表示,N个顶点表示N个入境/出 ...
 - P2610 [ZJOI2012]旅游 树的直径
		
这个题就是建图不太好建,但是我们一想,三角形貌似只能两两挨着,最后会变成一个二叉树,所以问题就变成求树的直径.建图用pair套map超级简单. 题干: 到了难得的暑假,为了庆祝小白在数学考试中取得的优 ...
 
随机推荐
- 《C++ Primer》P314中使用insert重写单词统计程序的扩展
			
编写程序统计并输出所读入的单词出现的次数 想与习题10-1相结合,也就是先输入几组 map<string, int>类型,存入vector中. 再输入单词word,如果已经存在则在key对 ...
 - ASP.NET MVC轻教程 Step By Step 9——分页
			
现在我们要把Index视图的留言信息进行分页显示. Step 1. 创建路由 我们希望以类似地址http://localhost:41583/Page1来表示第一页,Page2表示第二页,以此类推.在 ...
 - jquery 滑动动画
			
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <head> ...
 - register 不允许 block 模式,而默认的是
			
Exception in thread "main" java.nio.channels.IllegalBlockingModeException at java.nio.chan ...
 - EasyPHP的Apache报错
			
今天安装了最新版本的软件:EasyPHP-DevServer-14.1VC11-install.exe 启动报错: 打开Cport软件: 可见80端口被系统占用,导致Apache不能启动. (1)手动 ...
 - 手动更改WIN远程桌面端口,要改两个地方的注册表哟
			
看到我的服务器有老多人在用桌面连接,虽然进不去,但他们不停地试,浪费掉不少服务器资源,我看到网上有不少关于修改3389的介绍.修改3389的工具,一些工具一点用都没有,纯属扯淡.修改后照样是3389. ...
 - 【POJ2478】Farey Seque
			
题意: 就是求2~n的所有欧拉函数值的和,这里就用到了快速求欧拉函数的方法.(不能暴力求了,不然必定TLE啊) 说说欧拉筛法,感觉十分机智啊~~ 对于上述代码的几个问题: 1.问:为什么i%prime ...
 - php使用domdocument读取xml文件
			
使用domdocument读取xml文件需要用到以下几个方法和属性: 方法: 1:读取xml文件:load() 2:获取标签的对象数组:getElementByTagName() 3:对象数组的索引: ...
 - Eclipse 项目有红感叹号、小红叉
			
红感叹号: 问题原因]:工程中classpath中指向的包路径错误 [解决办法]:右键项目名称 BuildPath ---> Configure Build Paht...中,然后上面有几个选项 ...
 - 《深度探索c++对象模型》chapter1关于对象对象模型
			
在c++中,有2种class data member:static和nostatic,以及3钟class member function:static,nostatic和virtual.已知下面这个c ...