【BZOJ】【1040】【ZJOI2008】骑士

时间:2022-11-22 14:09:55

树形DP/基环树DP


  我掉坑掉了好多……

  这题图比较特殊,每个连通块都是一棵基环树(我一开始以为图是连通的了……sigh,我说为什么网上的题解都要累加ans……),那么对于一棵基环树,我们先dfs找到这个环,再随便断一条环上的边使它变成一棵树,就可以TreeDP啦~但是有个问题:这两个点不能同时选,所以:假设A不选,那么就以A为根做一次DP,此时B选不选都可以,取tmp=f[A][0](不选A的最大收益);再假设B不选,以B为根再做一次DP,取f[B][0],那么tmp和f[B][0]的较大值就是这个连通块的最大收益。

  但是……有种奇特的环是二元环……说人话就是重边QAQ这种情况下我原来那种判to!=fa[x]的方法就没法找到环了……我就加了个特判,如果环大小为0就直接对根TreeDP算答案= =

  我的方法时空复杂度好像比较高……但个人感觉还是蛮好懂的

 /**************************************************************
Problem: 1040
User: Tunix
Language: C++
Result: Accepted
Time:2152 ms
Memory:64836 kb
****************************************************************/ //BZOJ 1040
#include<vector>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
#define pb push_back
using namespace std;
inline int getint(){
int v=,sign=; char ch=getchar();
while(ch<''||ch>''){ if (ch=='-') sign=-; ch=getchar();}
while(ch>=''&&ch<=''){ v=v*+ch-''; ch=getchar();}
return v*sign;
}
const int N=1e6+,INF=~0u>>;
typedef long long LL;
/******************tamplate*********************/
int to[N<<],next[N<<],head[N],cnt;
void add(int x,int y){
to[++cnt]=y; next[cnt]=head[x]; head[x]=cnt;
to[++cnt]=x; next[cnt]=head[y]; head[y]=cnt;
}
/********************edge***********************/
int n,a[N],circle[N],tot;
LL f[N][],ans,v[N];
int dfn[N],low[N],fa[N],dfs_clock;
bool vis[N];
void dfs(int x){
dfn[x]=low[x]=++dfs_clock;
for(int i=head[x];i;i=next[i])
if (to[i]!=fa[x]){
if (!dfn[to[i]]){
fa[to[i]]=x;
dfs(to[i]);
low[x]=min(low[x],low[to[i]]);
}else low[x]=min(low[x],dfn[to[i]]);
}
if (low[x]<dfn[x]) circle[++tot]=x;
}
void Tree_DP(int x){
vis[x]=; f[x][]=v[x]; f[x][]=;
for(int i=head[x];i;i=next[i])
if (!vis[to[i]]){
Tree_DP(to[i]);
f[x][]+=f[to[i]][];
f[x][]+=max(f[to[i]][],f[to[i]][]);
}
}
int main(){
#ifndef ONLINE_JUDGE
freopen("1040.in","r",stdin);
freopen("1040.out","w",stdout);
#endif
n=getint();
F(i,,n){
v[i]=getint();
a[i]=getint(); add(i,a[i]);
}
F(i,,n) if (!dfn[i]){
dfs(i); LL tmp;
// F(i,1,tot) printf("%d ",circle[i]);puts("");
if (tot){
memset(vis,,sizeof vis);
Tree_DP(circle[]);
tmp=f[circle[]][];
memset(vis,,sizeof vis);
Tree_DP(circle[]);
tmp=max(tmp,f[circle[]][]);
}else{
Tree_DP(i);
tmp=max(f[i][],f[i][]);
}
ans+=tmp; tot=;
}
printf("%lld\n",ans);
return ;
}

1040: [ZJOI2008]骑士

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 2232  Solved: 857
[Submit][Status][Discuss]

Description

Z
国的骑士团是一个很有*的组织,帮会中汇聚了来自各地的精英。他们劫富济贫,惩恶扬善,受到社会各界的赞扬。最近发生了一件可怕的事情,邪恶的Y国发动
了一场针对Z国的侵略战争。战火绵延五百里,在和平环境中安逸了数百年的Z国又怎能抵挡的住Y国的军队。于是人们把所有的希望都寄托在了骑士团的身上,就
像期待有一个真龙天子的降生,带领正义打败邪恶。骑士团是肯定具有打败邪恶*的能力的,但是骑士们互相之间往往有一些矛盾。每个骑士都有且仅有一个自己
最厌恶的骑士(当然不是他自己),他是绝对不会与自己最厌恶的人一同出征的。战火绵延,人民生灵涂炭,组织起一个骑士军团加入战斗刻不容缓!国王交给了你
一个艰巨的任务,从所有的骑士中选出一个骑士军团,使得军团内没有矛盾的两人(不存在一个骑士与他最痛恨的人一同被选入骑士军团的情况),并且,使得这支
骑士军团最具有战斗力。为了描述战斗力,我们将骑士按照1至N编号,给每名骑士一个战斗力的估计,一个军团的战斗力为所有骑士的战斗力总和。

Input

第一行包含一个正整数N,描述骑士团的人数。接下来N行,每行两个正整数,按顺序描述每一名骑士的战斗力和他最痛恨的骑士。

Output

应包含一行,包含一个整数,表示你所选出的骑士军团的战斗力。

Sample Input

3
10 2
20 3
30 1

Sample Output

30

HINT

对于100%的测试数据,满足N ≤ 1 000 000,每名骑士的战斗力都是不大于   1 000 000的正整数。

Source

[Submit][Status][Discuss]

【BZOJ】【1040】【ZJOI2008】骑士的更多相关文章

  1. BZOJ 1040&colon; &lbrack;ZJOI2008&rsqb;骑士 基环加外向树

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

  2. bzoj 1040&colon; &lbrack;ZJOI2008&rsqb;骑士 環套樹DP

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

  3. bzoj 1040&colon; &lbrack;ZJOI2008&rsqb;骑士 树形dp

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

  4. &lbrack;BZOJ 1040&rsqb;&lbrack;ZJOI2008&rsqb;骑士

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

  5. Bzoj 1040 &lbrack;ZJOI2008&rsqb;骑士 题解

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

  6. &lbrack;BZOJ 1040&rsqb; &lbrack;ZJOI2008&rsqb; 骑士 【基环&plus;外向树DP】

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

  7. bzoj 1040 &lbrack;ZJOI2008&rsqb;骑士(基环外向树,树形DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1040 [题意] 给一个基环森林,每个点有一个权值,求一个点集使得点集中的点无边相连且权 ...

  8. BZOJ 1040&colon; &lbrack;ZJOI2008&rsqb;骑士(基环树dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1040 题意: 思路: 这是基环树,因为每个人只会有一个厌恶的人,所以每个节点只会有一个父亲节点,但是 ...

  9. BZOJ 1040&colon; &lbrack;ZJOI2008&rsqb;骑士 &vert; 在基环外向树上DP

    题目: http://www.lydsy.com/JudgeOnline/problem.php?id=1040 题解: 我AC了 是自己写的 超开心 的 考虑断一条边 这样如果根节点不选答案一定正确 ...

  10. BZOJ 1040 &lbrack;ZJOI2008&rsqb;骑士 &lpar;基环树&plus;树形DP&rpar;

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

随机推荐

  1. React-Native性能优化点

    shouldComponentUpdate 确保组件在渲染之后不需要再更新的,即静态组件,尽量在其中增加shouldComponentUpdate方法,防止二次消耗所产生的性能消耗 shouldCom ...

  2. 更新CocoaPods

    终端输入 : sudo gem install -n /usr/local/bin cocoapods –pre 更新了CocoaPods后,在原来的工程中执行了pod install命令后,报这样的 ...

  3. nexus2&period;1&period;2的配置

    最近在学习maven,逐渐接触到私服的搭建,也就着手学习使用nexus了,在http://www.sonatype.org/nexus/go网站上nexus最新版本的是,不过版本要同jvm的版本匹对, ...

  4. oracle直通车6关于rman备份恢复数据文件,以及创建分区表的实验

    1.创建一张表,在表上创建一个索引,分别查询表,索引各自分配了多少个extents,多少个数据块以及总共占用空间的大小(bytes). 答:创建一张表t,为字段object_id创建索引t_objec ...

  5. java&lowbar;有返回值线程&lowbar;提前加载例子

    package com.demo.test3; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionE ...

  6. Java API ——StringBuffer类

    1.StringBuffer类概述 1)我们如果对字符串进行拼接操作,每次拼接,都会构建一个新的String对象,既耗时,又浪费空间.而StringBuffer就可以解决这个问题 2)线程安全的可变字 ...

  7. 一个&period;net的程序员如何转到java的&quest;

    先说明,大佬请忽略我这篇文章, 我是一个做了5年的纯种C#开发人,  我在此仅记录一下我转java的过程.都知道, java是开源的,所以它的开发工具贼多,不像.net, 直接地表最强的IDE. 像现 ...

  8. 使用vue&plus;koa实现一个简单的图书小程序(1)

    这个系列的博客用来记录我开发时候遇到的问题以及学习到的知识 边做边学: 前后端分离,高内聚低耦合小程序端使用了mpvue 内部使用了vuejs的语法 来做整个小程序的渲染层 后端使用的是koa2搭建一 ...

  9. numpy的shape 和 gt的x、y坐标之间容易引起误会

    用numpy来看shape,比如np.shape(img_data),会得到这样的结果(600,790,3) 注意:600不是横坐标,而是表示多少列,790才是横坐标 用numpy测试就可以看出: & ...

  10. BootStrap------之模态框1

    <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8& ...