Codeforces Round #635 (Div. 2)
Contest Info
| Solved | A | B | C | D | E | F |
|---|---|---|---|---|---|---|
| 4/6 | O | O | Ø | Ø |
- O 在比赛中通过
- Ø 赛后通过
- ! 尝试了但是失败了
- - 没有尝试
Solutions
C. Linova and Kingdom
题意:
给定一颗以$1$为根的树,现在要选定$k$个结点为黑点,一个黑点的贡献为从他出发到根节点经过的白点数量
问黑点贡献总和最大为多少。
思路:
- 最直接的想法黑点肯定是位于深度越深的点越好,我们会得到这样一个性质:假设我们选择了一个点,那么该点的所有后代也将会被选择(因为子节点的深度比父节点大,必然优先选完所有子节点才会选他的父节点)。
- 一个黑点产生的贡献为其深度减去到根路径中黑点的数量。
- 直接按照上述思路贪心不好思考,考虑转化一下贡献的计算方法:我们减去黑点的数量时在其祖先结点再减。也就是说每个黑点会减去其子树$size$。
- 那么对于所有点按照$deep−size$进行排序,从大到小贪心选即可。
因为一个点选择了所有子树也会被选,并且显然子树的$deep−size$更大,所以容易证明这种贪心是正确的。
比赛的时候我就是很简单的按照深度贪心,写完测试的时候发现这明显是错的。想想后觉得添加黑点会对在它下方的点造成影响就感觉超级麻烦,的确没想到的有两点:1.一个点选择了所有子树也会被选(这个很关键). 2.能把对答案的贡献转化到父节点,这题想法还是很妙的。
#include <cstdio>
#include <cstring>
#include <algorithm>
#define ll long long
using namespace std;
const int maxn = 2e5+100;
int n, k, u, v;
int t, head[maxn], dep[maxn], siz[maxn];
int ans[maxn];
struct node{
int to, nxt;
}e[maxn<<1];
bool cmp(int a, int b){
return a > b;
}
void add(int u, int v){
e[++t].nxt = head[u];
e[t].to = v;
head[u] = t;
}
void dfs(int u, int fa){
siz[u] = 1;
for(int i = head[u]; i; i = e[i].nxt){
int v = e[i].to;
if(v==fa) continue;
dep[v] = dep[u] + 1, dfs(v, u);
siz[u] += siz[v];
}
ans[u] = dep[u] - siz[u] + 1;
}
int main(){
scanf("%d%d", &n, &k);
for(int i = 1; i <= n-1; i++){
scanf("%d%d", &u, &v);
add(u, v), add(v, u);
}
dfs(1, 0);
sort(ans+1, ans+1+n, cmp);
ll res = 0;
for(int i = 1; i <= k; i++) res += ans[i];
printf("%lld", res);
}
D.Xenia and Colorful Gems
题意:
从数组$a,b,c$中分别找到三个数$x,y,z$使得$(x−y)^2+(y−z)^2+(z−x)^2$最小
思路:
我最开始的想法是,固定$b[i]$,从$a$和$c$中找距离$b[i]$最近的数更新$ans$就可以了。但是这样又有个问题,就是距离$b[i]$最近的两个数之间的距离未必是最小的,所以这样还是有问题的。
有个博主给出的思想我觉得是可行易懂的:
观察可以得到,答案的三个数字肯定是从小到大的,两边的数肯定是对应集合中到中间的那个数的距离最小的,但是中间的那个数是哪个集合的呢,对此我们就可以进行枚举,反正才三个数组
#include <cstdio>
#include <cstring>
#include <algorithm>
#define ll long long
#define inf 9e18
using namespace std;
const int maxn = 1e5+100;
int T, na, nb, nc;
ll a[maxn], b[maxn], c[maxn], ans;
ll cal(ll x, ll y, ll z){
return (x-y)*(x-y)+(y-z)*(y-z)+(z-x)*(z-x);
}
void sovle(ll *x, int nx, ll *y, int ny, ll *z, int nz){
for(int i = 1; i <= ny; i++){
int px1 = lower_bound(x+1, x+1+nx, y[i])-x, px2 = upper_bound(x+1, x+1+nx, y[i])-x-1;
int pz1 = lower_bound(z+1, z+1+nz, y[i])-z, pz2 = upper_bound(z+1, z+1+nz, y[i])-z-1;
if(pz1!=nz+1&&px2) ans = min(ans, cal(x[px2],y[i],z[pz1]));
if(px1!=nx+1&&pz2) ans = min(ans, cal(z[pz2],y[i],x[px1]));
}
}
int main(){
scanf("%d", &T);
while(T--){
scanf("%d%d%d", &na, &nb, &nc);
for(int i = 1; i <= na; i++) scanf("%lld", &a[i]);
for(int i = 1; i <= nb; i++) scanf("%lld", &b[i]);
for(int i = 1; i <= nc; i++) scanf("%lld", &c[i]);
sort(a+1, a+1+na), sort(b+1, b+1+nb), sort(c+1, c+1+nc);
ans = inf;
sovle(b, nb, a, na, c, nc);
sovle(a, na, b, nb, c, nc);
sovle(a, na, c, nc, b, nb);
printf("%lld\n", ans);
}
}
Reference:
https://codeforces.ml/blog/entry/75996
https://www.cnblogs.com/heyuhhh/p/12710644.html
https://blog.csdn.net/DevourPower/article/details/105549725
https://blog.csdn.net/Fire_xch/article/details/105550781
Codeforces Round #635 (Div. 2)的更多相关文章
- Codeforces Round #635 (Div. 2) 题解
渭城朝雨浥轻尘,客舍青青柳色新. 劝君更尽一杯酒,西出阳关无故人.--王维 A. Ichihime and Triangle 网址:https://codeforces.com/contest/133 ...
- Codeforces Round #635 (Div. 2)部分(A~E)题解
虽然打的是div1,但最后半小时完全处于挂机状态,不会做1C,只有个 \(O(n^3)\) 的想法,水了水论坛,甚至看了一下div2的AB,所以干脆顺便写个div2的题解吧,内容看上去还丰富一些(X) ...
- Codeforces Round #635 (Div. 1)
传送门 A. Linova and Kingdom 题意: 给定一颗以\(1\)为根的树,现在要选定\(k\)个结点为黑点,一个黑点的贡献为从他出发到根节点经过的白点数量. 问黑点贡献总和最大为多少. ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
随机推荐
- 【递推】P1028数的计算
题目相关 题目描述 我们要求找出具有下列性质数的个数(包含输入的正整数 n). 先输入一个正整数 n(n ≤1000),然后对此正整数按照如下方法进行处理: 不作任何处理: 在它的左边加上一个正整数, ...
- Docker一秒进阶
tar包: 从tar包导入:docker load < xxxx.tar docker run -d -p 8080:80 --name [名字] -v `pwd`:/usr/share/ngi ...
- Linux 中软链接和硬链接的使用
Linux 链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link). 硬链接和软链接 硬链接 --- ln 要链接的文件 新硬链接名 软连接 --- l ...
- MyISAM与InnoDB两者之间区别与选择(转)
Mysql在V5.1之前默认存储引擎是MyISAM:在此之后默认存储引擎是InnoDB MyISAM:默认表类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Acces ...
- ctfshow—web—web3
打开靶机 提示是文件包含漏洞 测试成功 https://d7c9f3d7-64d2-4110-a14b-74c61f65893c.chall.ctf.show/?url=../../../../../ ...
- ORACLE查找占用临时表空间多的SESSION
需要使用SYS用户登录查看 /* Formatted on 2020/12/30 上午 11:17:12 (QP5 v5.163.1008.3004) */ SELECT k.inst_id &quo ...
- SQL 语法速成手册
本文针对关系型数据库的一般语法.限于篇幅,本文侧重说明用法,不会展开讲解特性.原理. 一.基本概念 数据库术语 数据库(database) - 保存有组织的数据的容器(通常是一个文件或一组文件). 数 ...
- uni-app开发经验分享十三:实现手机扫描二维码并跳转全过程
最近使用 uni-app 开发 app ,需要实现一个调起手机摄像头扫描二维码功能,官网API文档给出了这样一个demo: // 允许从相机和相册扫码 uni.scanCode({ success: ...
- 基于Redo Log和Undo Log的MySQL崩溃恢复流程
在之前的文章「简单了解InnoDB底层原理」聊了一下MySQL的Buffer Pool.这里再简单提一嘴,Buffer Pool是MySQL内存结构中十分核心的一个组成,你可以先把它想象成一个黑盒子. ...
- 六个你不知道的PR快捷键,拯救你的剪辑效率
5G时代到来,会剪辑视频的人,无论在校园还是未来步入职场都很吃香.对于普通人来说,视频处理也成为了一个通用技能.PR是我们大多数人剪辑中,经常会用到的剪辑工具,之前的文章中已经给大家总结了pr的一些提 ...