Codeforces Round #384 (Div. 2) ABCD
一场比较简单的div2 电脑出了点问题 所以在比赛中理论ac了ACD 除了爆int这种事情之外..
A 一个人想从a到b 移动的花费这么定义 如果初始点和到达点类型相同 就不花钱 反之花距离差的绝对值的钱 并且是直接移动
判断ab的类型 一样就输出0 反之1 因为如果不能直接零花费到b的话 就花1花费走到一个和b类型相同的点 然后零花费移动
B 给出一个串的增长规律 问经过n-1次操作后 k位是多少
规律是这样的 一开始只有1 进行一次操作 就把当前串复制一遍粘在后面 然后在这两个相同串之间插入一个当前没有使用过的最小数字
1 -> 121 -> 1213121 -> 121312141213121 这样
这个串是很对称的 如果k处于当前串的中间 我们可以很容易的确定他是多少
如果处于当前中点的右边 即k处在复制粘贴来的串上 就减去一个东西 让他平移到原串上
如果处于当前中点的左边 就不做修改
k最后一定会在当前串的中间的
持续让一个很长的串进行长度减半 直到k处在当前串中点
C 给出一个n 求出abc 使 2/n = 1/a + 1/b + 1/c 且 a != b a !=c b != c
样例很明确...其实就是a = n b = n+1 c = a*b 可以证明满足一切
唯独满足不了n = 1 因为在没有相同数字的前提下 1/1 + 1/2 + 1/3 无法达到2 别的一定小于它
于是特判n = 1
D 给出一棵树 找两个点 获得他们的子树权值和 并且这两个点的子树没有交集 点有点权 以1为根
树形dp
如果从一个点的所有子树中 选出来两个最大的 一定是合法(不相交)的
答案就是根的子树的最大值和次大值的加和
维护的办法是 维护每个点的 最大子树值 和 选两个子树的加和的最大值
这个点的最大子树值很好求 不断递归就好了
两个子树的加和的最大值 可以直接从每个子树的加和最大值继承来
也可能是 这个点每个儿子节点的最大子树 选出来最大值与次大值相加
最后如果根节点的最大值+次大值不存在 那就是没法选出来两个不相交子树
虽然写的代码是爆int的..
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<map>
#include<vector>
#include<queue>
#include<malloc.h>
using namespace std;
#define L long long
vector<int >q[200050];
int n ;
L a[200050];
L b[200050];
L dfs1(int fa ,int u){
b[u] = a[u];
for(int i = 0;i<q[u].size();i++){
int v = q[u][i];
if(v == fa)continue;
b[u] += dfs1(u,v);
}
return b[u];
}
L dp[200050][3];
void dfs(int fa,int u){
dp[u][0] = b[u];
dp[u][1] = -9999999999;
dp[u][2] = b[u];
L maxx = -9999999999;
L maxx2 = -9999999999;
for(int i=0;i<q[u].size();i++){
int v = q[u][i];
if(v == fa)continue;
dfs(u,v);
dp[u][2] = max(dp[u][2],dp[v][2]);
if(dp[v][2]!= -9999999999){
if(maxx == -9999999999){
maxx = dp[v][2];
}
else {
if(dp[v][2] > maxx){
maxx2 = maxx;
maxx = dp[v][2];
}
else {
if(maxx2 == -9999999999 || dp[v][2] > maxx2){
maxx2 = dp[v][2];
}
}
} }
}
if(maxx2!= -9999999999){
dp[u][1] = maxx2 + maxx;
}
for(int i =0;i<q[u].size();i++){
int v = q[u][i];
if(v == fa)continue;
dp[u][1] = max(dp[u][1] , dp[v][1]);
} }
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%lld",&a[i]);
q[i].clear();
}
for(int i=1;i<n;i++){
int u,v;
scanf("%d%d",&u,&v);
q[u].push_back(v);
q[v].push_back(u);
}
dfs1(-1,1);
dfs(-1,1);
if(dp[1][1]!= -9999999999)printf("%lld\n",dp[1][1]);
else printf("Impossible\n");
}
Codeforces Round #384 (Div. 2) ABCD的更多相关文章
- Codeforces Round #258 (Div. 2)[ABCD]
Codeforces Round #258 (Div. 2)[ABCD] ACM 题目地址:Codeforces Round #258 (Div. 2) A - Game With Sticks 题意 ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #268 (Div. 2) ABCD
CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...
- Codeforces Round #449 (Div. 2)ABCD
又掉分了0 0. A. Scarborough Fair time limit per test 2 seconds memory limit per test 256 megabytes input ...
- Codeforces Round #384 (Div. 2) E. Vladik and cards 状压dp
E. Vladik and cards 题目链接 http://codeforces.com/contest/743/problem/E 题面 Vladik was bored on his way ...
- Codeforces Round #384 (Div. 2)D - Chloe and pleasant prizes 树形dp
D - Chloe and pleasant prizes 链接 http://codeforces.com/contest/743/problem/D 题面 Generous sponsors of ...
- Codeforces Round #384 (Div. 2) C. Vladik and fractions 构造题
C. Vladik and fractions 题目链接 http://codeforces.com/contest/743/problem/C 题面 Vladik and Chloe decided ...
- Codeforces Round #384 (Div. 2)B. Chloe and the sequence 数学
B. Chloe and the sequence 题目链接 http://codeforces.com/contest/743/problem/B 题面 Chloe, the same as Vla ...
- Codeforces Round #384 (Div. 2) A. Vladik and flights 水题
A. Vladik and flights 题目链接 http://codeforces.com/contest/743/problem/A 题面 Vladik is a competitive pr ...
随机推荐
- 无密钥登录的自动脚本实现(ssh-copy-id、expect免交互输入脚本)
感谢朋友支持本博客,欢迎共同探讨交流,由于能力和时间有限,错误之处在所难免,欢迎指正! 如有转载,请保留源作者博客信息. Better Me的博客:blog.csdn.net/tantexian 如需 ...
- c# 不同窗体之间传值和调用
1.子窗体事件刷新父窗体界面值 子窗体定义委托和事件 //声明一个委托 public delegate void DisplayUpdateDelegate(string str); //声明事件 p ...
- float 比较, 这是一个坑
为了方便随机关键产品数据,做了一个随机值列的方案,列字段类型设置为float. 在测试的两个随机值的时候, 故意设置了几个随机值相同保存到数据库表中, 这样问题就出来了. 详细如下: 当进行小于比较的 ...
- 【原创】js中input type=file的一些问题
1.介绍 在开发中,文件上传必不可少,input[type=file] 是常用的上传标签,但是它长得又丑.浏览的字样不能换,但是他长得到底有多丑呢.我们来看看在不同浏览器里的样子吧. <inpu ...
- .NET 程序集与命名空间
程序集 程序集(assembly)是一个或多个托管模块,以及一些资源文件的逻辑组合. 组成部分 Windows文件首部 CLR文件首部 程序集清单 类型元数据 MSIL(CIL)代码 嵌入资源集 作用 ...
- python中如何避免中文是乱码
这个问题是一个具有很强操作性的问题.我这里有一个经验总结,分享一下,供参考:首先,提倡使用utf-8编码方案,因为它跨平台不错.经验一:在开头声明: # -*- coding: utf-8 -*- 有 ...
- meta标签用法总结
注:本文并非本人撰写,摘自百度百科 meta标签用来描述一个HTML网页文档的属性,例如作者.日期和时间.网页描述.关键词.页面刷新等. 一.作用: META标签是HTML标记HEAD区的 ...
- UE移植到SAE云平台
应用架在新浪的SAE上,而同时功能中又需要用上编辑器,鉴于百度的UEditor功能强大,可定制,文档全,所以理所当然的用它.而新浪把本地文件的IO操作禁止了,使得UEdiotr的图片上传.附件和在线涂 ...
- UC浏览器 分享到朋友圈和微信好友 分类: JavaScript 2015-04-28 14:45 615人阅读 评论(1) 收藏
用手机UC浏览器访问新浪微博,会注意到有这样的两个分享按钮: 在手机端浏览器里,点击分享按钮,就可以启动微信客户端并分享到微信.研究了下其源代码,存在这样的一个js:http://mjs.sinaim ...
- 简述Linux命令初使用
.cd 命令 cd 命令经常使用来改变目录 root@test:~# cd /home/user/Desktop root@test:~# cd .. 返回上一级目录 root@test:~# cd ...