【题目链接】

http://www.lydsy.com/JudgeOnline/problem.php?id=1040

【题意】

给一个基环森林,每个点有一个权值,求一个点集使得点集中的点无边相连且权值和最大。

【思路】

注意题目中的有向边其实就是无向边。然后有多个联通块,每个联通块中有且仅有一个环。

如果没有环的话可以用树形DP,解决这个问题。

设f[i][0],f[i][1]分别表示以i为根,不选/选i时的最大权值。则有转移式:

f[i][0]=sigma{ max(f[son(i)][0],f[son(i)][1]) }

f[i][1]=sigma{ f[son(i)][0] }

对于一个环,我们任选一条边拆开,然后以边的两点U,V为根做树形DP,再考虑边UV存在,有两种情况:

  1) 强制不选U,V任意,环的贡献为以U做DP的f[U][0]

  2) 强制不选V,U任意,环的贡献为以V做DP的f[V][0]

【科普】

基环外向树就是一棵树加一条边(好厉害的名字<_<

【代码】

 #include<cstdio>
#include<cstring>
#include<iostream>
#define FOR(a,b,c) for(int a=(b);a<=(c);a++)
using namespace std; typedef long long ll;
const int N = 1e6+; struct Edge {
int v,nxt;
}e[N<<];
int en=,front[N];
void adde(int u,int v)
{
en++; e[en].v=v,e[en].nxt=front[u],front[u]=en;
} int n,w[N],vis[N];
ll f[N][]; ll read()
{
char c=getchar(); ll f=,x=;
while(!isdigit(c)) {if(c=='-') f=-; c=getchar(); };
while(isdigit(c)) x=x*+c-'',c=getchar();
return x*f;
} int U,V,E;
void dfs(int u,int fa)
{
vis[u]=;
for(int i=front[u];i;i=e[i].nxt) {
if((i^)==fa) continue;
int v=e[i].v;
if(vis[v]) {
U=u; V=v; E=i;
continue;
}
dfs(v,i);
}
}
void treedp(int u,int fa,int ban)
{
f[u][]=w[u],f[u][]=;
for(int i=front[u];i;i=e[i].nxt) {
if((i^)==fa) continue;
if(i==ban||(i^)==ban) continue;
int v=e[i].v;
treedp(v,i,ban);
f[u][]+=max(f[v][],f[v][]);
f[u][]+=f[v][];
}
} int main()
{
n=read();
int v;
FOR(i,,n) {
w[i]=read(),v=read();
adde(i,v),adde(v,i);
}
ll ans=;
FOR(i,,n) if(!vis[i]) {
dfs(i,-);
treedp(U,-,E);
ll tmp=f[U][];
treedp(V,-,E);
tmp=max(tmp,f[V][]);
ans+=tmp;
}
printf("%lld",ans);
return ;
}

bzoj 1040 [ZJOI2008]骑士(基环外向树,树形DP)的更多相关文章

  1. 1040: [ZJOI2008]骑士~基环外向树dp

    Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬.最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的侵略战争.战火绵延五百里,在和平环境中 ...

  2. BZOJ 1040: [ZJOI2008]骑士 基环加外向树

    1040: [ZJOI2008]骑士 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1190  Solved: 465[Submit][Status] ...

  3. BZOJ 1040 [ZJOI2008]骑士 (基环树+树形DP)

    <题目链接> 题目大意: Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬.最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的 ...

  4. BZOJ 1040: [ZJOI2008]骑士 [DP 环套树]

    传送门 题意:环套树的最大权独立集 一开始想处理出外向树树形$DP$然后找到环再做个环形$DP$ 然后看了看别人的题解其实只要断开环做两遍树形$DP$就行了...有道理! 注意不连通 然后洛谷时限再次 ...

  5. [BZOJ 1040] [ZJOI2008] 骑士 【基环+外向树DP】

    题目链接:BZOJ - 1040 题目分析 这道题目的模型就是一个图,不一定联通,每个连通块的点数等于边数. 每个连通块都是一个基环+外向树.即树上增加了一条边. 如果是树,就可以直接树形DP了.然而 ...

  6. [bzoj] 1040 骑士 || 基环外向树dp

    原题 给出n个点n条边和每个点的点权,一条边的两个断点不能同时选择,问最大可以选多少. //图是一张基环外向树森林 是不是很像舞会啊- 就是多了一条边. 所以我们考虑一下对于一棵基环外向树,拆掉一条在 ...

  7. bzoj 1040: [ZJOI2008]骑士 树形dp

    题目链接 1040: [ZJOI2008]骑士 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3054  Solved: 1162[Submit][S ...

  8. BZOJ1040 骑士 基环外向树

    1040: [ZJOI2008]骑士 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 6421  Solved: 2544[Submit][Status ...

  9. bzoj 1040: [ZJOI2008]骑士 環套樹DP

    1040: [ZJOI2008]骑士 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1755  Solved: 690[Submit][Status] ...

随机推荐

  1. 论反馈信息如何推动 IT 运维团队进步?

    我们还记得<快乐大本营>中经典游戏----快乐传真吗?游戏规则是:很多人站一排,只有第一个人才看到最准确的信息,用东西隔着,戴耳机,一一将从前一个人获得的信息传递下去,最后一个人说出推测的 ...

  2. 几款开源的图形界面库(GUI Libraries)

    SmartWin++ 遵循BSD许可协议的C++ GUI库,建立在Windows API之上,但仍可以通过使用WineLib在Linux/xNix上使用.也支持Pocket PC和基于Windows ...

  3. 李洪强iOS开发之宏定义方法来初始化一个单例对象

    单例的使用: .m 为了方便实用,只要将以下代码定义在header文件或者.pch文件即可: // .h #define singleton_interface(class) + (instancet ...

  4. HeadFirst设计模式之模板方法模式

    一. 1.The Template Method defines the steps of an algorithm and allows subclasses to provide the impl ...

  5. ArcGIS学习记录—ArcGIS ArcMap编辑状态中线打断的问题

    摘要:在处理数据时,我们经常会遇到线打断的问题,比如需要指定在线上某处打断线,或者新建网络数据集时需要在线的交点处打段线等等.现将桌面版中我所遇到的线打断的工具总结如下: 在ArcGIS矢量处理数据时 ...

  6. log4j:ERROR A "org.jboss.logging.appender.FileAppender" object is not assignable to a "org.apache.lo .

    log4j:ERROR A "org.jboss.logging.appender.FileAppender" object is not assignable to a &quo ...

  7. php Late Static Bindings延迟静态绑定

    官网说道: As of PHP 5.3.0, PHP implements a feature called late static bindings which can be used to ref ...

  8. python学习笔记二--列表的使用

    一.基本列表操作 1. 合并‘+’:左右两边必须均为列表 可以用str(),%,list()做类型的转换后再做合并 2. 重复‘*’: 3. 迭代和解析: x作为for循环里步进变量,由于列表是序列, ...

  9. poj2886Who Gets the Most Candies? (约瑟夫环)

    http://poj.org/problem?id=2886 单点更新 初始位置都是1 如果这个人出去 位置变为0 利用线段树求区间k值 k值的计算如下 如果这个数值是负的 那么下一个人的就是((k- ...

  10. POI根据EXCEL模板,修改内容导出新EXCEL (只支持HSSF)

    package excelPoiTest; import java.io.File; import java.io.FileInputStream; import java.io.FileOutput ...