旅游 bzoj-2657 Zjoi-2012

题目大意题目链接

注释:$1\le K\le 2\cdot 10^5$。


想法:这题...

感觉和上一个题的提示有些类似,就是题目生怕你不知道这是一道对偶图的题... ...

我们先把它转成对偶图。然后我们只把分割n变形的线段两侧的点之间连边,这样就是一棵树。

紧接着我们想要遍历最多的城市,其实就是找树上直径。树形dp即可。

最后,附上丑陋的代码... ...

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N 200010
using namespace std;
int to[N<<1],nxt[N<<1],head[N],joa;
int tot[(N<<1)+N],f[N][2],cnt;
struct Node
{
int x,y,p;
}edge[(N<<1)+N];
inline bool cmp(const Node &x,const Node &y)
{
return x.x==y.x?x.y<y.y:x.x<y.x;
}
inline void add(int x,int y)
{
to[++joa]=y;
nxt[joa]=head[x];
head[x]=joa;
}
int ans=0;
void dfs(int pos,int fa)
{
for(int i=head[pos];i;i=nxt[i])
{
if(to[i]==fa) continue;
dfs(to[i],pos);
if(f[pos][0]<f[to[i]][0]+1) f[pos][1]=f[pos][0],f[pos][0]=f[to[i]][0]+1;
else f[pos][1]=max(f[pos][1],f[to[i]][0]+1);
}
ans=max(ans,f[pos][0]+f[pos][1]);
}
int main()
{
int n; cin >> n ;
for(int i=1;i<n-1;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
edge[++cnt].x=min(x,y),edge[cnt].y=max(x,y); edge[cnt].p=i;
edge[++cnt].x=min(x,z),edge[cnt].y=max(x,z); edge[cnt].p=i;
edge[++cnt].x=min(y,z),edge[cnt].y=max(y,z); edge[cnt].p=i;
}
sort(edge+1,edge+cnt+1,cmp);
for(int i=1;i<=cnt;i++)
{
// printf("%d %d %d\n",edge[i].x,edge[i].y,edge[i].p);
if(i==1||abs(edge[i].x-edge[i].y)==1||(edge[i].x==1&&edge[i].y==n)) continue;
if(edge[i].x==edge[i-1].x&&edge[i].y==edge[i-1].y)
{
// printf("Fuck %d %d\n",edge[i-1].p,edge[i].p);
add(edge[i].p,edge[i-1].p);
add(edge[i-1].p,edge[i].p);
}
}
dfs(1,1);
// for(int i=1;i<=n-2;i++)
// {
// printf("%d %d\n",f[i][0],f[i][1]);
// }
printf("%d\n",ans+1);
return 0;
}

小结:裙子课件什么题都有qwq/hy

[bzoj2657][Zjoi2012]旅游 journey_ 对偶图_树形dp的更多相关文章

  1. BZOJ_1864_[Zjoi2006]三色二叉树_树形DP

    BZOJ_1864_[Zjoi2006]三色二叉树_树形DP 题意: 分析:递归建树,然后DP,从子节点转移. 注意到红色和蓝色没有区别,因为我们可以将红蓝互换而方案是相同的.这样的话我们只需要知道当 ...

  2. BZOJ_3573_[Hnoi2014]米特运输_树形DP+hash

    BZOJ_3573_[Hnoi2014]米特运输_树形DP+hash 题意: 给你一棵树每个点有一个权值,要求修改最少的权值,使得每个节点的权值等于其儿子的权值和且儿子的权值都相等. 分析: 首先我们 ...

  3. B20J_4027_[HEOI2015]兔子与樱花_树形DP

    B20J_4027_[HEOI2015]兔子与樱花_树形DP 题意: 很久很久之前,森林里住着一群兔子.有一天,兔子们突然决定要去看樱花.兔子们所在森林里的樱花树很特殊.樱花树由n个树枝分叉点组成,编 ...

  4. BZOJ_1040_[ZJOI2008]骑士_树形DP

    BZOJ_1040_[ZJOI2008]骑士_树形DP 题意: Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各 界的赞扬.最近发生了一件可怕的事情,邪 ...

  5. BZOJ_1060_时态同步_树形DP

    BZOJ_1060_时态同步_树形DP 题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1060 分析:水水的树形DP. 用儿子的最大值更新父亲, ...

  6. BZOJ_1827_[Usaco2010 Mar]gather 奶牛大集会_树形DP

    BZOJ_1827_[Usaco2010 Mar]gather 奶牛大集会_树形DP 题意:Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会.当然,她会选择最方便的地点来 ...

  7. BZOJ_4726_[POI2017]Sabota?_树形DP

    BZOJ_4726_[POI2017]Sabota?_树形DP Description 某个公司有n个人, 上下级关系构成了一个有根树.其中有个人是叛徒(这个人不知道是谁).对于一个人, 如果他 下属 ...

  8. BZOJ_1304_[CQOI2009]叶子的染色_树形DP

    BZOJ_1304_[CQOI2009]叶子的染色_树形DP Description 给一棵m个结点的无根树,你可以选择一个度数大于1的结点作为根,然后给一些结点(根.内部结点和叶子均可)着以黑色或白 ...

  9. BZOJ_4033_[HAOI2015]树上染色_树形DP

    BZOJ_4033_[HAOI2015]树上染色_树形DP Description 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并 将其他的 ...

随机推荐

  1. CF482C Game with Strings

    题意 你和你的朋友玩一个游戏,游戏规则如下. 你的朋友创造 n 个长度均为 m 的不相同的字符串,然后他随机地选择其中一个.他选择这些字符串的概率是相等的,也就是说,他选择 n 个字符串中的每一个的概 ...

  2. C#结构体+结构体与类的区别

    C# 结构(Struct) 在 C# 中,结构是值类型数据结构.它使得一个单一变量可以存储各种数据类型的相关数据.struct 关键字用于创建结构. C# 结构的特点 您已经用了一个简单的名为 Boo ...

  3. ACM_数数有多少(第二类Stirling数-递推dp)

    数数有多少 Time Limit: 2000/1000ms (Java/Others) Problem Description: 小财最近新开了一家公司,招了n个员工,但是因为资金问题,办公楼只有m间 ...

  4. Linux环境下RPM包相互依赖的解决办法

    Linux环境下安装Oracle11gR2提示缺少"Package: elfutils-libelf-devel-0.125    FAILED"包,按照提示安装该包时又提示缺少依 ...

  5. 锚点、target="page1"、浮标回到顶部(该点未实现,能力不足)

    <html> <head> <meta charset="utf-8"> <title>链接</title> <! ...

  6. JSON基础 JS操作JSON总结

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式.同时,JSON是 JavaScript 原生格式,这意 ...

  7. js数组的各种方法

    1.检测数组 ①Instanceof: if(value instanceof Array){ } 它假定只有一个全局执行环境,若网页中包含多个框架,则存在多个不同的全局执行环境,则Instanceo ...

  8. 面试中的一些小问题之html5和html4的区别?

    HTML5建立的一些新规则: 新特性应该基于HTML.CSS.DOM.JavaScript: 减少对外部插件的需求,如flash将会用video标签和audio标签代替: 更加优秀的错误处理: 更多取 ...

  9. Farseer.net轻量级开源框架 中级篇:数据绑定

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: DbFactory数据工厂 下一篇:Farseer.net轻量级开源框架 中级篇: ...

  10. 实战:tcp链接rst场景tcpdump分析

    RST为重置报文段,它会导致TCP连接的快速拆迁,且不需要ack进行确认. 1.针对不存在的端口的连请求 客户端: #include <unistd.h> #include <sys ...