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个人去 ,根据题意我们可以很容易的得到如下递推公式 ...
随机推荐
- Rotate Image leetcode java
题目: You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwis ...
- Python爬虫实例(三)代理的使用
一些网站会有相应的反爬虫措施,例如很多网站会检测某一段时间某个IP的访问次数,如果访问频率太快以至于看起来不像正常访客,它可能就会会禁止这个IP的访问.所以我们需要设置一些代理服务器,每隔一段时间换一 ...
- Mongo = get size of single document
Object.bsonsize(db.test.findOne({type:"auto"}))
- Multiple Instance .NET Windows Service
It's not readily apparent how to install a Windows Service multiple times on a single machine. At fi ...
- glValidateProgram只用于调试
glValidateProgram应该只用于调试,用于release版本中会影响性能.以下是详细描述: Before doing so, however, we might want to che ...
- SharePoint中Rating相关的字段。
From: https://sharepoint.stackexchange.com/questions/194197/how-to-manipulate-likeby-nooflikes-rat ...
- FancyBox-经典的jQuery Lightbox插件
在线演示 本地下载 FancyBox 是一款非常优秀的弹窗插件,能够为图片.HTML内容和其它任务的多媒体内容提供优雅的弹出缩放效果.作为是最流行的 Lightbox 插件之一,可以通过 fitToV ...
- 通过项目逐步深入了解Mybatis<一>
Mybatis Mybatis 和 SpringMVC 通过订单商品案例驱动 官方中文地址:http://www.mybatis.org/mybatis-3/zh/ 官方托管地址:https://gi ...
- Oracle 之 保留两位小数
项目需要使用百分率,保留2位小数,只用 round 和 trunc 函数都可以实现(round(_data,2) ),只是格式不是很工整,对格式要求不严谨的情况下使用 round 即可. 以下是比较方 ...
- 【树莓派】树莓派与XBMC及Kodi、LibreELEC插件(一)
网上高人多. 高手在民间,饭桶在机关. 越用树莓派,越发现这玩意儿的潜力,我想,未来我们用它,可以做很多事情. 最近在看树莓派的应用场景,看到网上有人用它做电视盒子. 参考相关文章,简单实践了一下,整 ...