Description

Input

仅有一行,不超过500000个字符,表示一个二叉树序列。

Output

输出文件也只有一行,包含两个数,依次表示最多和最少有多少个点能够被染成绿色。

Sample Input

1122002010


Sample Output

5 2

树形dp……

先讲最大值怎么求

令f[i][0]表示i这个点不染绿色,i下面的子树最多能取多少个绿色的点

f[i][1]表示i这个点染了绿色,i下面的子树最多能取多少个绿色的点

首先考虑对于一个点,如果染了绿色,那么根据题目所述,它的左右儿子必须染得跟它不一样,就是必须不是绿色

所以f[i][1]=f[r[i]][0]+f[l[i]][0]+1

然后如果这个点不染绿色,那么一个节点与其左右儿子必须颜色不同,就是说必须红绿蓝各一,那么还是只有一个绿色

枚举从左右儿子中哪一个转移过来就好了

所以f[i][0]=max(f[l[i]][0]+f[r[i]][1],f[l[i]][1]+f[r[i]][0])

最小值同理

#include<cstdio>
#define MAX 300010
int f[MAX][2];
int l[MAX],r[MAX];
int treesize=1;
inline int max(int a,int b)
{return a>b?a:b;}
inline int min(int a,int b)
{return a<b?a:b;}
inline void read(int now)
{
char ch=getchar();
if (ch=='0')return;
treesize++;l[now]=treesize;read(treesize);
if (ch=='2')
{
treesize++;
r[now]=treesize;
read(treesize);
}
}
inline void dp1(int now)
{
if (!now)return;
dp1(r[now]);dp1(l[now]);
f[now][1]=f[l[now]][0]+f[r[now]][0]+1;
f[now][0]=max(f[l[now]][0]+f[r[now]][1],f[l[now]][1]+f[r[now]][0]);
}
inline void dp2(int now)
{ if (!now)return;
dp2(r[now]);dp2(l[now]);
f[now][1]=f[l[now]][0]+f[r[now]][0]+1;
f[now][0]=min(f[l[now]][0]+f[r[now]][1],f[l[now]][1]+f[r[now]][0]);
}
int main()
{
read(1);
dp1(1);
printf("%d ",max(f[1][0],f[1][1]));
for (int i=1;i<=treesize;i++){f[i][0]=0;f[i][1]=0;}
dp2(1);
printf("%d\n",min(f[1][0],f[1][1]));
}

最新文章

  1. 使用Eclipse创建Maven Web工程
  2. 国内外三个不同领域巨头分享的Redis实战经验及使用场景
  3. 基于struts2和hibernate的分页实现
  4. 正在运行的android程序,按home键之后退回到桌面,在次点击程序图标避免再次重新启动程序解决办法
  5. 《Entity Framework 6 Recipes》中文翻译系列 (41) ------ 第七章 使用对象服务之标识关系中使用依赖实体与异步查询保存
  6. jquery基础知识汇总
  7. c# ref 的作用
  8. c/c++ 对象内存布局
  9. &lt;转载&gt; 你应该更新的Java知识之常用程序库(一)
  10. 整齐地输出n的平方,立方
  11. 设计包含min函数的栈
  12. JavaScript中Ajax的get和post请求
  13. C语言-getopt函数
  14. 安装完CentOS 7 Minimal之后,从头打造桌面工作环境
  15. Delphi 3D Glscene安装
  16. DB2 表空间监控
  17. Volatile的那些事
  18. sql 根据表名查找存储过程
  19. linux环境下运行程序格式错误的问题,bash: ./helloworld: cannot execute binary file: Exec format error
  20. 【Golang 接口自动化04】 解析接口返回JSON串

热门文章

  1. logstash 中的贪婪匹配
  2. 【转】linux tree命令以树形结构显示文件目录结构 ---- 不错
  3. VM虚拟机安装苹果雪豹操作系统
  4. 3 Sum 解答
  5. Direct3D 顶点缓存
  6. vs2010 正式版官方下载地址
  7. Android窗口管理服务WindowManagerService计算窗口Z轴位置的过程分析
  8. FullCalendar 的学习笔记(一)
  9. Linq 标准查询操作符三
  10. Webform服务器控件调用JS