题目链接

一棵树,树中包含TRUE、FALSE、AND、OR四种结点,其中TRUE和FALSE是叶子结点,AND和OR结点的儿子包含多个结点,现在要求执行最少次数的以下操作:

  • 把AND变成OR
  • 把OR变成AND

使得整棵树的bool值结果翻转。

思路

只考虑当前结点和它的儿子。

要想改变当前结点的值,有两种方法:

  • 改变当前结点的操作
  • 改变当前结点的儿子结点的值

有时甚至需要把这两种方法结合起来,比如:当前结点为AND,它的儿子们全为TRUE。这是要改变当前结点的值,可能要把当前结点改为OR,并且把某个儿子改为FALSE。

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; public class Main {
final int MAX_VLUE = 100000; class Node {
List<Node> son = new ArrayList<>();
String value;
int parent;
int reverseValue = -1;
boolean nowValue = false;
boolean inited = false; Node(String value, int parent) {
this.value = value;
this.parent = parent;
} int reverseOne(boolean toValue) {
int min = MAX_VLUE;
for (Node i : son) {
if (i.getValue() == toValue) return 0;
min = Math.min(min, i.reverse());
}
return min;
} int reverseAll(boolean toValue) {
int s = 0;
for (Node i : son) {
if (i.getValue() != toValue) {
s += i.reverse();
}
}
return s;
} //翻转需要的步数
int reverse() {
if (reverseValue != -1) return reverseValue;
if (value.equals("TRUE") || value.equals("FALSE")) return MAX_VLUE;
if (value.equals("AND")) {
if (nowValue) {
reverseValue = Math.min(reverseOne(false), 1 + reverseAll(false));
} else {
reverseValue = Math.min(reverseAll(true), 1 + reverseOne(true));
}
} else if (value.equals("OR")) {
if (nowValue) {
reverseValue = Math.min(1 + reverseOne(false), reverseAll(false));
} else {
reverseValue = Math.min(reverseOne(true), 1 + reverseAll(true));
}
}
return reverseValue;
} boolean getValue() {
if (inited) return nowValue;
inited = true;
if (value.equals("TRUE")) {
nowValue = true;
return true;
} else if (value.equals("FALSE")) {
nowValue = false;
return false;
} else if (value.equals("AND")) {
nowValue = son.stream().allMatch(Node::getValue);
return nowValue;
} else if (value.equals("OR")) {
nowValue = son.stream().anyMatch(Node::getValue);
return nowValue;
}
return false;
}
} Main() {
Scanner cin = new Scanner(System.in);
int N = cin.nextInt();
Node[] a = new Node[N + 1];
a[0] = new Node("AND", 0);
for (int i = 1; i <= N; i++) {
int parent = cin.nextInt();
String value = cin.next();
a[i] = new Node(value, parent);
}
int root = 1;
for (int i = 1; i <= N; i++) {
a[a[i].parent].son.add(a[i]);
if (a[i].parent == 0) {
root = i;
}
}
a[root].getValue();
int step = a[root].reverse();
if (step >= MAX_VLUE) {
System.out.println(-1);
} else {
System.out.println(step);
}
} public static void main(String[] args) {
new Main();
}
}

hihocoder217周 树形DP的更多相关文章

  1. 【bzoj2060】[Usaco2010 Nov]Visiting Cows拜访奶牛 树形dp

    题目描述 经过了几周的辛苦工作,贝茜终于迎来了一个假期.作为奶牛群中最会社交的牛,她希望去拜访N(1<=N<=50000)个朋友.这些朋友被标号为1..N.这些奶牛有一个不同寻常的交通系统 ...

  2. 【BZOJ】2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛(树形dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2060 裸的树形dp d[x][1]表示访问x的数量,d[x][0]表示不访问x的数量 d[x][1] ...

  3. poj3417 LCA + 树形dp

    Network Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4478   Accepted: 1292 Descripti ...

  4. COGS 2532. [HZOI 2016]树之美 树形dp

    可以发现这道题的数据范围有些奇怪,为毛n辣么大,而k只有10 我们从树形dp的角度来考虑这个问题. 如果我们设f[x][k]表示与x距离为k的点的数量,那么我们可以O(1)回答一个询问 可是这样的话d ...

  5. 【BZOJ-4726】Sabota? 树形DP

    4726: [POI2017]Sabota? Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 128  Solved ...

  6. 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)

    题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...

  7. 树形DP

    切题ing!!!!! HDU  2196 Anniversary party 经典树形DP,以前写的太搓了,终于学会简单写法了.... #include <iostream> #inclu ...

  8. BZOJ 2286 消耗战 (虚树+树形DP)

    给出一个n节点的无向树,每条边都有一个边权,给出m个询问,每个询问询问ki个点,问切掉一些边后使得这些顶点无法与顶点1连接.最少的边权和是多少.(n<=250000,sigma(ki)<= ...

  9. POJ2342 树形dp

    原题:http://poj.org/problem?id=2342 树形dp入门题. 我们让dp[i][0]表示第i个人不去,dp[i][1]表示第i个人去 ,根据题意我们可以很容易的得到如下递推公式 ...

随机推荐

  1. Java Math.sqrt()方法

    描述 java.lang.Math.sqrt(double a) 返回正确舍入的一个double值的正平方根.特殊情况: 如果参数是NaN或小于为零,那么结果是NaN. 如果参数是正无穷大,那么结果为 ...

  2. windows及linux环境下永久修改pip镜像源的方法

    一.在windows环境下修改pip镜像源的方法(以python3.5为例) (1):在windows文件管理器中,输入 %APPDATA% (2):会定位到一个新的目录下,在该目录下新建pip文件夹 ...

  3. Laravel validate 500异常 添加手机验证,中文验证与Validator验证的“半个”生命周期

    今天来讲一下,Lumen的Validator函数 1 2 3 4 5 6 7 8 9 10 11 use Validator;   ...   Class .. {   public function ...

  4. Android -- Serializable和Parcelable需要注意的

    Serializable 静态变量序列化不会被保存 public class Test implements Serializable { private static final long seri ...

  5. Kafka:ZK+Kafka+Spark Streaming集群环境搭建(十五)Spark编写UDF、UDAF、Agg函数

    Spark Sql提供了丰富的内置函数让开发者来使用,但实际开发业务场景可能很复杂,内置函数不能够满足业务需求,因此spark sql提供了可扩展的内置函数. UDF:是普通函数,输入一个或多个参数, ...

  6. oracle 嵌套查询

    select dat.id, dat.voucher_id, dat.type, dat.state, dat.start_point, dat.start_floor, dat.end_point, ...

  7. Office 超级录屏如何旋转视频90度之后保存

    打开视频转换专家   添加视频后点击编辑,然后在旋转的地方设置旋转,应用   输出可以正常播放  

  8. 变址values(, %edi, 4)和间址4(%edi)

    <汇编语言程序设计>Richard Blum著:5.2.4 在内存和寄存器之间传送数据   使用变址的内存位置: 可以在一个命令中指定把多个值存放到内存中: values:     .in ...

  9. Spring+MyBatis纯注解零XML整合(4)

    不得不说,利用XML作为配置文件是一个非常好的想法,它可以轻松地实现配置集中化,而且修改之后无需再次编译.然而,由于大多数情况下开发者基本都会拿到程序的源码,加之对于各种XML配置文件一般情况下也只有 ...

  10. angularjs中templateUrl的路径问题

    angularjs中templateUrl的路径问题 templateUrl的相对路径是现对于app主页面的,因为template使用js来加载的.