hihocoder217周 树形DP
题目链接
一棵树,树中包含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的更多相关文章
- 【bzoj2060】[Usaco2010 Nov]Visiting Cows拜访奶牛 树形dp
题目描述 经过了几周的辛苦工作,贝茜终于迎来了一个假期.作为奶牛群中最会社交的牛,她希望去拜访N(1<=N<=50000)个朋友.这些朋友被标号为1..N.这些奶牛有一个不同寻常的交通系统 ...
- 【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] ...
- poj3417 LCA + 树形dp
Network Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 4478 Accepted: 1292 Descripti ...
- COGS 2532. [HZOI 2016]树之美 树形dp
可以发现这道题的数据范围有些奇怪,为毛n辣么大,而k只有10 我们从树形dp的角度来考虑这个问题. 如果我们设f[x][k]表示与x距离为k的点的数量,那么我们可以O(1)回答一个询问 可是这样的话d ...
- 【BZOJ-4726】Sabota? 树形DP
4726: [POI2017]Sabota? Time Limit: 20 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 128 Solved ...
- 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)
题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...
- 树形DP
切题ing!!!!! HDU 2196 Anniversary party 经典树形DP,以前写的太搓了,终于学会简单写法了.... #include <iostream> #inclu ...
- BZOJ 2286 消耗战 (虚树+树形DP)
给出一个n节点的无向树,每条边都有一个边权,给出m个询问,每个询问询问ki个点,问切掉一些边后使得这些顶点无法与顶点1连接.最少的边权和是多少.(n<=250000,sigma(ki)<= ...
- POJ2342 树形dp
原题:http://poj.org/problem?id=2342 树形dp入门题. 我们让dp[i][0]表示第i个人不去,dp[i][1]表示第i个人去 ,根据题意我们可以很容易的得到如下递推公式 ...
随机推荐
- wamp设置自定义域名访问php网站
wamp是一个在window系统下很不错的php开发套件,一般我都是使用此套件在本地进行开发和测试的 特别是alias功能特别好,可以同时开发N个php网站而不互相影响 但alias有一个问题,它其实 ...
- 【python】使用py3-bencode打开torrent文件
没想到这个原始版本访问量超过了后继版本,估计有些流量是搜索引擎带来的,有些人并不会点击左边“我的随笔”去找新的版本. 现把后继版本地址贴一下:http://www.cnblogs.com/xiande ...
- Android 自定义 ListView 上下拉动“刷新最新”和“加载更多”歌曲列表
本文内容 环境 测试数据 项目结构 演示 参考资料 本文演示,上拉刷新最新的歌曲列表,和下拉加载更多的歌曲列表.所谓"刷新最新"和"加载更多"是指日期.演示代码 ...
- LintCode: Valid Parentheses
C++ stack<char|int|string>, push(), pop(), top(), empty(), size() class Solution { public: /** ...
- 【linux】Ubuntu中shell脚本无法使用source的原因及解决方法
问题现象: shell脚本中source aaa.sh时提示 source: not found 原因: ls -l `which sh` 提示/bin/sh -> dash 这说明是用dash ...
- Windows Python+Eclipse环境配置
参考这几篇博客: 1:http://www.cnblogs.com/realh/archive/2010/10/04/1841907.html 2:http://www.cnblogs.com/min ...
- 解决mybatis报错Result Maps collection does not contain value for java.lang.Integer
解决办法:1.检查mybatis的xml配置 2.在某处肯定有配错了的,如"resultMap" -->"resultType" [html] view ...
- 用Java位运算实现加减乘除四则运算
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6412875.html 感谢博客:http://blog.csdn.net/itismelzp/article/ ...
- GoldenGate 12c + Oracle 12c Multitenant Container databases
下面为GoldenGate 12c + Oracle 12c Multitenant Container databases例子 1.安装OGG 源 端OGG: C:\Oracle\product\1 ...
- .NET 工具生成引擎概述
Mark Michaelis 微软中国MSDN 过去几年大家一直都在使用 .NET Core(有这么久吗?)并且都知道“生成系统”经历了重大改变,不论是终止对 Gulp 的内置支持,还是放弃 Proj ...