旅游 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. Hive insert into directory 命令输出的文件没有列分隔符分析和解决

    参考资料:http://stackoverflow.com/questions/16459790/hive-insert-overwrite-directory-command-output-is-n ...

  2. CSS知识点整理(1):CSS语法,层叠次序,选择器,其他重要方面。

    1. css的全称 2. CSS的层叠次序:优先级由低到高 ·浏览器设置 ·外部样式表 或者 内部样式表 —— 就近原则 ·内联样式 3. CSS的3种形式,以及每种形式的语法格式 ——注意样式表的为 ...

  3. php redis 操作大全

    类和方法 用法 Redis类 类RedisException 预定义的常量 Redis类 说明:创建一个Redis客户端 例 $redis = new Redis(); 类RedisException ...

  4. [Windows Server 2012] MySQL更改数据库引擎(MyISAM改为INNODB)

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com ★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频. ★ 本节我们将带领大家:更改MyS ...

  5. python学习笔记(5)—— tuple 本质探究

    >>> t=(1,2,3,['a','b','c'],4,5) >>> t[3][0]='x' >>> t (1, 2, 3, ['x', 'b' ...

  6. Python 开发初识

    从今天开始记录自己的python开发之路,用博客记录自己的学习经历,以及学习小结,小的项目模块,努力充实,做最好的自己!!!

  7. 【转】WITH AS 用法

    转载自:http://blog.csdn.net/shaochao14/article/details/6223052 一.WITH AS的含义 WITH AS短语,也叫做子查询部分(subquery ...

  8. UI开发模式-容器模式

    UI开发模式-容器模式 通用容器: 配置容器.

  9. day02python

    ''' 列表 定义:在[]内,可以存放多个任意类型的值,并以逗号隔开. 一般用于存放学生的爱好,课堂的周期等等... ''' students=['钱垚','李小龙','张全蛋','赵铁柱'] pri ...

  10. LTTng

    Waiting for dig... http://frederic-wou.net/lttng/