1864. [ZJOI2006]三色二叉树【树形DP】
Description

Input
仅有一行,不超过500000个字符,表示一个二叉树序列。
Output
输出文件也只有一行,包含两个数,依次表示最多和最少有多少个点能够被染成绿色。
Sample Input
Sample Output
5 2
f[x][1\2\3]代表x点染红绿蓝色的最多有多少个点染成绿色
g[x][1\2\3]代表最少
#include<iostream>
#include<cstring>
#include<cstdio>
#define N (1000000+100)
using namespace std;
char st[N];
int Father[N],Son[N][];
int a[N],maxn;
int f[N][],g[N][]; void Build(int x,int fa)
{
maxn=max(maxn,x);
Father[x]=fa;
if (!Son[fa][]) Son[fa][]=x;
else Son[fa][]=x;
if (a[x]>=) Build(x+,x);
if (a[x]==) Build(maxn+,x);
} void Dp(int x)
{
f[x][]=;f[x][]=;f[x][]=;
g[x][]=;g[x][]=;g[x][]=;
if (Son[x][]) Dp(Son[x][]);
if (Son[x][]) Dp(Son[x][]);
f[x][]+=max( f[Son[x][]][]+f[Son[x][]][] , f[Son[x][]][]+f[Son[x][]][] );
f[x][]+=max( f[Son[x][]][]+f[Son[x][]][] , f[Son[x][]][]+f[Son[x][]][] );
f[x][]+=max( f[Son[x][]][]+f[Son[x][]][] , f[Son[x][]][]+f[Son[x][]][] ); g[x][]+=min( g[Son[x][]][]+g[Son[x][]][] , g[Son[x][]][]+g[Son[x][]][] );
g[x][]+=min( g[Son[x][]][]+g[Son[x][]][] , g[Son[x][]][]+g[Son[x][]][] );
g[x][]+=min( g[Son[x][]][]+g[Son[x][]][] , g[Son[x][]][]+g[Son[x][]][] );
} int main()
{
scanf("%s",st);
for (int i=;i<=strlen(st)-;++i)
a[i+]=st[i]-'';
Build(,);
Son[][]=Son[][]=;
Dp();
printf("%d ",max(max(f[][],f[][]),f[][]));
printf("%d",min(min(g[][],g[][]),g[][]));
}
1864. [ZJOI2006]三色二叉树【树形DP】的更多相关文章
- BZOJ 1864: [Zjoi2006]三色二叉树( 树形dp )
		
难得的ZJOI水题...DFS一遍就行了... ----------------------------------------------------------------------- #inc ...
 - BZOJ 1864: [Zjoi2006]三色二叉树 树形DP + 读入
		
Description Input 仅有一行,不超过500000个字符,表示一个二叉树序列. Output 输出文件也只有一行,包含两个数,依次表示最多和最少有多少个点能够被染成绿色. 题解:本题大水 ...
 - 【BZOJ1864】[Zjoi2006]三色二叉树 树形DP
		
1864: [Zjoi2006]三色二叉树 Description Input 仅有一行,不超过500000个字符,表示一个二叉树序列. Output 输出文件也只有一行,包含两个数,依次表示最多和最 ...
 - BZOJ1864[ZJOI2006]三色二叉树[树形DP]
		
1864: [Zjoi2006]三色二叉树 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 773 Solved: 548[Submit][Status] ...
 - [luogu2585 ZJOI2006] 三色二叉树 (树形dp)
		
传送门 Description Input 输入文件名:TRO.IN 输入文件仅有一行,不超过500000个字符,表示一个二叉树序列. Output 输出文件名:TRO.OUT 输出文件也只有一行,包 ...
 - 洛谷 2585 [ZJOI2006]三色二叉树——树形dp
		
题目:https://www.luogu.org/problemnew/show/P2585 可以把不是绿色的记成一种.仔细一想不会有冲突.如果自己是绿色,孩子的不同颜色不会冲突:如果自己不是绿色,自 ...
 - 【BZOJ-1864】三色二叉树     树形DP
		
1864: [Zjoi2006]三色二叉树 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 659 Solved: 469[Submit][Status] ...
 - 【BZOJ】1864: [Zjoi2006]三色二叉树
		
1864: [Zjoi2006]三色二叉树 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 1295 Solved: 961[Submit][Status ...
 - 1864: [Zjoi2006]三色二叉树
		
1864: [Zjoi2006]三色二叉树 链接 分析: 做得最智障的一题了... 首先中间输出两个数之间没空格(换行居然也过了...), 写了dp[i][0/1/2],后来知道其实dp[i][0/1 ...
 - 三色二叉树——树形dp
		
三色二叉树 题目描述 一棵二叉树可以按照如下规则表示成一个由 \(0.1.2\) 组成的字符序列,我们称之为"二叉树序列 \(S\) ": \(0\) 该树没有子节点. \(1S_ ...
 
随机推荐
- [android] 手机卫士黑名单功能(短信拦截)
			
前面我们把需要拦截的手机号都存储和展示出来了,接下来是使用广播接收者拦截短信了,这个广播接收者需要和一个服务绑定,服务开启的时候,接收者存在,服务停掉时,接收者关闭 在service包下定义一个类Ca ...
 - Nginx面试
			
声明:此文章非本人所 原创,是别人分享所得,如有知道原作者是谁可以联系本人,如有转载请加上此段话 1.请解释一下什么是 Nginx? Nginx是一个 web服务器和反向代理服务器,用于 HTTP.H ...
 - static dictionary methods of text compression
			
Now I will introduce a way to compress a text. When we are confronted with numerous data, and the da ...
 - THUSC2017 游记
			
你若安好,便是晴天. Day 0 中午就要出发了,上午浮躁的不行,根本写不下题去. 到了火车站之后发现教练和lyc和ztc在4车靠近5车的那一边,然而我在5车靠近4车的那边,尴尬…… 本来是想着上了火 ...
 - 转:ubuntu 18.04 LTS 安装 java10(JDK) 及问题说明
			
原文地址:ubuntu 18.04 LTS 安装 java10 及问题说明 1.下载相应的安装包,例如jdk-10.0.1_linux-x64_bin.tar.gz.下载地址: http://www. ...
 - 【SQL基础】三种类别语句
			
SQL 语句主要可以划分为以下 3 个类别. DDL(Data Definition Languages)语句:数据定义语言,这些语句定义了不同的数据段.数据库.表.列.索引等数据库对象的定义.常用的 ...
 - button的OnClickListener的三种实现方法
			
onclick事件的定义方法,分为三种,分别为在xml中进行指定方法:在Actitivy中new出一个OnClickListenner():实现OnClickListener接口三种方式. 代码分别如 ...
 - XSS学习(未完..)
			
前言 XSS 漏洞原理非常简单,实际应用中非常灵活,于是通过 prompt(1) to win 来学习学习 正文 工具 分析正则表达式 https://regex101.com/ http://xss ...
 - 扩展LV手记
			
情景概览 系统:CentOS Linux release 7.4.1708 (Core) 磁盘情况: 目标:将sda3扩展到sda2下的centos-root虚拟盘上 操作步骤 1.建立新的PV # ...
 - windows 命令行使用p4
			
首先,p4的命令行真的恶心,要不是非要用我一定换成git(逃) 参考网站:https://www.perforce.com/manuals/v15.1/cmdref/p4_add.html 全程尝试各 ...