题目链接

一棵树,树中包含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. Gradle Groovy 基础语法 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  2. protobuf Protocol Buffers 简介 案例 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  3. css之图片羽化处理

    需求: 对图片做css羽化处理 实现: <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  4. 设置虚拟机IP

    重启虚拟机 重启后,查看虚拟机IP ip a 虚拟机已有自己的IP 输入虚拟机用户

  5. 网易的Spark技术实践

    http://www.infoq.com/cn/news/2014/04/netease-spark-practice?utm_source=infoq&utm_medium=popular_ ...

  6. win8下Source Insight has not been installed completely问题的解决

    系统:windows8 软件:Source Insight 3.5 安装后打开总是提示如下图错误,没法使用. 卸载重新安装好多次,还是不行,百度一下,终于找到方法,记录一下,方便以后查找. 解决方法: ...

  7. java去除字符串后面的\0

    java去除字符串后面的\0 private String filterCode(String string) { if (string != null) { string = string.trim ...

  8. 转:在centos7上安装memcache

    转:https://www.liquidweb.com/kb/how-to-install-memcached-on-centos-7/ http://devdocs.magento.com/guid ...

  9. glGetString(GL_VERSION) returns “OpenGL ES-CM 1.1” but my phone supports OpenGL 2

      [问] I'm trying to make an NDK based OpenGL application. At some point in my code, I want to check ...

  10. apache 反向代理的时候,通过域名访问是,出现跳转到ip或者无权访问的情况

    解决方法很简单,在配置反向代理的时候加上一行: ProxyPreserveHost On 例如:ProxyPass / http://202.112.0.1/ProxyPassReverse / ht ...