0827考试 T1
Description
有一棵树,每个点有一个权值,找到一个权值最大的"乙烷"模型。
"乙烷"模型是指:

其中黑点表示可以有0个或多个点。
Sample Input
8
1 1 1 1 1 1 1 1 //点权
1 2 //建树
1 3
1 4
1 5
2 6
2 7
2 8
Sample Output
8
看到这道题有点蒙,想了一会儿想出是树形DP了,就是不会写,就想着打个暴力,还没打对。。。(我吐了)
这道题正解就是树形DP,我们考虑它的状态是什么。

(我们cjh学长的画功真是太厉害了!)
0代表一个点,1代表一条链,2代表两条链...
那转移呢?

\(x\)代表父亲节点,\(to\)代表\(x\)的一个儿子。
我们是从叶子节点向根节点转移的,所以当\(x\)状态为0,\(to\)状态为1时,它是无法转移到一个合法的状态的(可以手画画)。
#include <iostream>
#include <cstdio>
#include <cctype>
#include <vector>
#include <cstring>
using namespace std;
inline long long read() {
long long s = 0, f = 1; char ch;
while(!isdigit(ch = getchar())) (ch == '-') && (f = -f);
for(s = ch ^ 48;isdigit(ch = getchar()); s = (s << 1) + (s << 3) + (ch ^ 48));
return s * f;
}
const int N = 1e5 + 5, inf = 1e9;
int n;
long long ans;
int a[N];
long long f[N][8];
vector <int> son[N];
void init() {
n = read();
for(int i = 1;i <= n; i++) a[i] = read();
for(int i = 1, x, y;i <= n - 1; i++) {
x = read(); y = read();
son[x].push_back(y);
son[y].push_back(x);
}
memset(f, 0xf3, sizeof(f));
}
void dfs(int x, int fa) {
f[x][0] = a[x];
long long tmp[8];
for(int i = 0;i < (int)son[x].size(); i++) {
int y = son[x][i]; if(y == fa) continue;
// cout << x << " " << y << endl;
dfs(y, x);
long long *u = f[x], *v = f[y];
for(int j = 0;j < 8; j++) tmp[j] = u[j];
tmp[1] = max(tmp[1], u[0] + max(v[0], v[1]));
tmp[2] = max(tmp[2], u[1] + max(v[0], v[1]));
tmp[3] = max(tmp[3], u[2] + max(v[0], v[1]));
tmp[4] = max(tmp[4], u[0] + max(v[3], v[4]));
tmp[5] = max(tmp[5], u[4] + max(v[0], v[1]));
tmp[5] = max(tmp[5], u[1] + max(v[3], v[4]));
tmp[6] = max(tmp[6], u[5] + max(v[0], v[1]));
tmp[6] = max(tmp[6], u[2] + max(v[3], v[4]));
tmp[7] = max(tmp[7], u[0] + max(v[6], v[7]));
// for(int j = 0;j < 8; j++) cout << tmp[j] << " ";
// cout << endl;
ans = max(ans, tmp[7]);
ans = max(ans, max(u[3], u[4]) + max(v[3], v[4]));
ans = max(ans, max(u[6], u[7]) + max(v[0], v[1]));
// cout << ans << endl;
for(int j = 0;j < 8; j++) u[j] = tmp[j];
}
}
void work() {
ans = -inf;
dfs(1, 0);
printf("%lld", ans);
}
int main() {
freopen("misaka.in","r",stdin); freopen("misaka.out","w",stdout);
init();
work();
fclose(stdin); fclose(stdout);
return 0;
}
(貌似这题是有点恶心哈)
0827考试 T1的更多相关文章
- 考试T1总结(又CE?!)
考试T1CE... 最近不适合考试 T1 扶苏是个喜欢一边听古风歌一边写数学题的人,所以这道题其实是五三原题.歌曲中的主人公看着墙边的海棠花,想起当年他其实和自己沿着墙边种了一排海棠,但是如今都已枯萎 ...
- 某考试T1 game
题目背景 无 题目描述 Alice 和 Bob 在一个圆环上玩游戏.圆环上有 n 个位置,按照顺时针顺序 依次标号为 1 到 n.Alice 和 Bob 分别有一个数字集合,集合中都是在 [1, n− ...
- 某考试 T1 arg
题目描述 给出一个长度为 m 的序列 A, 请你求出有多少种 1...n 的排列, 满足 A 是它的一个 LIS. 输入格式 第一行两个整数 n, m. 接下来一行 m 个整数, 表示 A. 输出格式 ...
- 某考试 T1 lcm
把lcm写成 (a+n)*(b+n) / gcd(a+n,b+n). 因为gcd可以辗转相减,所以就成了gcd(abs(a-b),a+n),一个常量一个变量之间的gcd,我们可以直接把abs(a-b) ...
- 2019.2.25考试T1, 矩阵快速幂加速递推+单位根反演(容斥)
\(\color{#0066ff}{题解}\) 然后a,b,c通过矩阵加速即可 为什么1出现偶数次3没出现的贡献是上面画绿线的部分呢? 考虑暴力统计这部分贡献,答案为\(\begin{aligned} ...
- 2019.2.14 考试T1 FFT
\(\color{#0066ff}{ 题目描述 }\) 衡水二中的机房里经常有人莫名其妙地犇雷,leizi很生气,决定要找出那个犇雷的人 机房有n个人,每个人都认为机房里有两个人可能会犇雷,其中第i个 ...
- 某考试 T1 fair (18.5.1版)
转化一下模型:每天可以选1也可以选0,但是任意前i天(i<=n)1的个数都必须>=0的个数,求总方案数/2^n. 然后可以发现这是一个经典题,随便推一下公式发现等于 C(n,n/2)/2 ...
- 某考试 T1 str
一开始死磕sam,发现根本没法做...... 后来想了想,反正匹配子串的大部分不是sam就是 二分+hash啊,,,于是就想了想二分+hash,发现好像可以做啊! 就是假设我们要让 s1[1] 映射到 ...
- 某考试 T1 monopoly
可以很容易的发现,如果选了最高的房子,那么就不能再选了:否则在左边选一坨合法的,在右边选一坨合法的,拼起来还是合法的. 所以我们可以处理出,每个数的控制区间[L,R] (保证这个区间是其他数都小于它的 ...
随机推荐
- 笨办法学习python3练习代码ex20.py 函数和文件
注意,还要在python3,就是ex20.py的同目录里面直接创建一个ex20.txt的文件.里面至少要有三行内容 #函数和文件 #readline:只读取文本文件的一行 #seek(0):将读写位置 ...
- swift基础_ set get方法 理解
swift中重写set get方法是这样的. 先定义一个变量,当调用set方法的时候,系统会有一个newValue, 将newValue赋值给我们定义的变量,然后从get方法返回去. swift中一般 ...
- 物联网实验Arduino(1)
回顾 我们使用的平台: Arduino 入门实验1 眨眼睛 /* Blink Turns an LED on for one second, then off for one second, repe ...
- C语言输出颜色
命令后界面输出颜色 嵌入式终端界面输出日志时,为了区分输出的有用信息.错误信息,可以给不同级别的输出加上不同的颜色,以方便查看. 下面是颜色的定义: //颜色宏定义 #define NONE &quo ...
- Json字符串与QVariantList 对象相互转换
在Qt中QVariantList 使用起来很方便,如果涉及到数据的传输,需要将QVariantList 数据转换为JsonArray字符串,这个转换Qt已经实现好了,只需要调用接口就可以完成转换,代码 ...
- HashMap:从源码分析到面试题
1 HashMap简介 HashMap是实现map接口的一个重要实现类,在我们无论是日常还是面试,以及工作中都是一个经常用到角色.它的结构如下: 它的底层是用我们的哈希表和红黑树组成的.所以我们在学习 ...
- Flink的状态编程和容错机制(四)
一.状态编程 Flink 内置的很多算子,数据源 source,数据存储 sink 都是有状态的,流中的数据都是 buffer records,会保存一定的元素或者元数据.例如 : ProcessWi ...
- java运算符二
一 赋值运算符 /* * 赋值运算符 * +=, -=, *=, /=, %= : * 上面的运算符作用:将等号左右两边计算,会将结果自动强转成等号左边的数据类型,再赋值给等号左边的 * 注意:赋值运 ...
- markdown基础使用技巧
markdown基础使用技巧 通过``创建代码形式,不同形式可以叠加(比如:斜体+加粗) 块级元素 通过return/Enter实现切换段落/创建段落 通过shift+return/enter 实现换 ...
- Excel 提取年月日①
问题场景 从任务数据表中比较所有任务的预计完成时间和实际完成时间,来判断该任务是逾期还是按期完成了,根据实际场景是不需要考虑时分秒,只需对比该任务预计完成和实际完成的年月日. 可通过提取年月日用函数进 ...