Codeforces Round #540 (Div. 3)

题目链接:https://codeforces.com/contest/1118

题目太多啦,解释题意都花很多时间...还有事情要做,就选一些题来写吧。

B. Tanya and Candies

题意:

在n个数中任意删去一个,如果这个数被删去后,剩余数的奇数和以及偶数和相等,那么就定义这个数为"好数"。现在问这n个数中有多少个“好数”。

题解:

预处理出奇数前缀和、偶数前缀和,删去一个数后所有的奇数位置和 就为前面的奇数和以及后面的偶数和。然后枚举+判断就行了。

代码如下:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 2e5+;
int n;
int a[N];
ll pre[N],sub[N];
int main(){
cin>>n;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
ll sum1=,sum2=;
for(int i=;i<=n;i++){
pre[i]=pre[i-];
sub[i]=sub[i-];
if(i&) pre[i]+=a[i];
else sub[i]+=a[i];
}
sum1=pre[n];sum2=sub[n];
ll sum=sum1+sum2;
ll ans = ;
for(int i=;i<=n;i++){
ll now =;
if(i&){
now+=pre[i-];
now+=sum-sub[i-]-sum1;
}else{
now+=sub[i-];
now+=sum-pre[i-]-sum2;
}
if(now*==sum-a[i]) ans++;
}
cout<<ans;
return ;
}

D2. Coffee and Coursework (Hard Version)

题意:

给出n杯咖啡,每杯咖啡能增加工作量ai,同时给出m即最终需要的工作量。

每一天都可以喝咖啡来增加工作量,但是在同一天中,每多喝一杯咖啡,相应增加的工作量就会多减少1。

最后问最少需要多少天,才能够完成工作量。

题解:

很显然,天数越多,工作越有可能被完成。所以可以二分天数,然后在此基础上,贪心地喝咖啡,也就是说,这x天的第1杯咖啡,都是权值最大的那些;第2杯就是次大的那些...以此类推。

这个题感觉也不是很难,就是二分+判断可行性,具体见代码吧:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e5+;
int n,m;
int a[N];
int check(int x){
int i;
ll sum=,cnt=;
for(i=;i<=n;i++){
sum+=a[i]-cnt;
if(i%x==) cnt++;
if(sum>=m) return true;
}
return false;
}
int main(){
cin>>n>>m;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
sort(a+,a+n+);
reverse(a+,a+n+);
int l=,r=1e9+,mid;
while(l<r){
mid=l+r>>;
if(check(mid)) r=mid;
else l=mid+;
}
if(l==1e9+) cout<<-;
else cout<<l;
return ;
}

F1. Tree Cutting (Easy Version)

题意:

给出一颗树,其中有些点被染为颜色1,有些被染为颜色2,还有些没被染色,就是颜色0。现在要求删去一条边,使得树变为两个部分,并且满足每一部分中不同时存在1或者2颜色。

现在问有多少条边删去后,满足条件。

题解:

这个题也不是很难...维护每个结点的cnt1,cnt2,分别表示以它为根的子树中,1颜色和2颜色有多少。

如果满足一个结点,以它为根的子树中,包含了所有的1或者2颜色,并且不包含另外一种颜色,那么答案就加一。

一个dfs就搞定了。

代码如下:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e5+;
int n,sum1,sum2;
int a[N],cnt1[N],cnt2[N];
vector <int> g[N];
int ans;
void dfs(int u,int fa){
if(a[u]==) cnt1[u]++;
if(a[u]==) cnt2[u]++;
for(auto v:g[u]){
if(v==fa) continue ;
dfs(v,u);
cnt1[u]+=cnt1[v];
cnt2[u]+=cnt2[v];
}
if(cnt1[u]==sum1 && !cnt2[u]) ans++;
if(!cnt1[u] && cnt2[u]==sum2) ans++;
}
int main(){
cin>>n;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
for(int i=;i<=n;i++){
if(a[i]==) sum1++;
if(a[i]==) sum2++;
}
for(int i=;i<n;i++){
int u,v;
scanf("%d%d",&u,&v);
g[u].push_back(v);
g[v].push_back(u);
}
dfs(,-);
cout<<ans;
return ;
}

Codeforces Round #540 (Div. 3) 部分题解的更多相关文章

  1. # Codeforces Round #529(Div.3)个人题解

    Codeforces Round #529(Div.3)个人题解 前言: 闲来无事补了前天的cf,想着最近刷题有点点怠惰,就直接一场cf一场cf的刷算了,以后的题解也都会以每场的形式写出来 A. Re ...

  2. Codeforces Round #557 (Div. 1) 简要题解

    Codeforces Round #557 (Div. 1) 简要题解 codeforces A. Hide and Seek 枚举起始位置\(a\),如果\(a\)未在序列中出现,则对答案有\(2\ ...

  3. Codeforces Round #538 (Div. 2) (A-E题解)

    Codeforces Round #538 (Div. 2) 题目链接:https://codeforces.com/contest/1114 A. Got Any Grapes? 题意: 有三个人, ...

  4. Codeforces Round #531 (Div. 3) ABCDEF题解

    Codeforces Round #531 (Div. 3) 题目总链接:https://codeforces.com/contest/1102 A. Integer Sequence Dividin ...

  5. Codeforces Round #527 (Div. 3) ABCDEF题解

    Codeforces Round #527 (Div. 3) 题解 题目总链接:https://codeforces.com/contest/1092 A. Uniform String 题意: 输入 ...

  6. Codeforces Round #499 (Div. 1)部分题解(B,C,D)

    Codeforces Round #499 (Div. 1) 这场本来想和同学一起打\(\rm virtual\ contest\)的,结果有事耽搁了,之后又陆陆续续写了些,就综合起来发一篇题解. B ...

  7. Codeforces Round #545 (Div. 1) 简要题解

    这里没有翻译 Codeforces Round #545 (Div. 1) T1 对于每行每列分别离散化,求出大于这个位置的数字的个数即可. # include <bits/stdc++.h&g ...

  8. Codeforces Round #624 (Div. 3)(题解)

    Codeforces Round #624 (Div.3) 题目地址:https://codeforces.ml/contest/1311 B题:WeirdSort 题意:给出含有n个元素的数组a,和 ...

  9. Codeforces Round #821(Div.2) (A-C) 题解

    Codeforces Round #821(Div.2) (A-C) A.Consecutive Sum 大致题意 给定一组共 n 个数据 ,如果俩个数的下标在 mod k 意义下同余,则可以交换a[ ...

随机推荐

  1. 基于物品的协同过滤算法(ItemCF)

    最近在学习使用阿里云的推荐引擎时,在使用的过程中用到很多推荐算法,所以就研究了一下,这里主要介绍一种推荐算法—基于物品的协同过滤算法.ItemCF算法不是根据物品内容的属性计算物品之间的相似度,而是通 ...

  2. SpringCloud IDEA 教学 (二) Eureka Service

    写在开头 本篇继续介绍基于Eureka的SpringCloud微服务搭建,回顾一下搭建过程, 第一步:建立一个服务注册中心: 第二步:建立微服务并注入到注册中心: 第三步:建立client端来访问微服 ...

  3. 虚拟机下 rm -rf / 尝试

    环境:虚拟机 系统版本:centOS 5.8.centOS 6.5 1. root权限:rm -rf / 2. root权限:rm -rf /* 测试结果:5.8下执行命令1,2,根目录文件被删除,系 ...

  4. POJ 3693 Maximum repetition substring(后缀数组)

    Description The repetition number of a string is defined as the maximum number R such that the strin ...

  5. POJ 2449 Remmarguts' Date(第k短路のA*算法)

    Description "Good man never makes girls wait or breaks an appointment!" said the mandarin ...

  6. Redis 错误摘记篇

    yum安装的redis提示如下报错,大概意思就是配置文件和redis-server进程文件版本不一致.. [root@vm-10-104-28-24 yum.repos.d]# redis-serve ...

  7. 基于NABCD评论“欢迎来怼”团队Alpha版作品

    NABCD分析 N(需求) 随着博客园网页版的出现,大家希望能够随时看自己博客,查看别人的博客,以及写博客,评论博客等功能.对于学生的我们,及时了解作业的动态很重要,电脑不能随时携带,但手机随身携带, ...

  8. OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解

    最近开始关注OpenGL ES 2.0 这是真正意义上的理解的第一个3D程序 , 从零开始学习 . 案例下载地址 : http://download.csdn.net/detail/han120201 ...

  9. LintCode-66.二叉树的前序遍历

    二叉树的前序遍历 给出一棵二叉树,返回其节点值的前序遍历. 样例 给出一棵二叉树 {1,#,2,3}, 返回 [1,2,3]. 挑战 你能使用非递归实现么? 标签 递归 二叉树 二叉树遍历 非递归 c ...

  10. (转)Linux NUMA引发的性能问题

    最近某客户的核心业务系统又出了翻译缓慢的情况.该问题在6月份也出现过,当时进行了一次调整. 我们首先来看下故障时间段的awr报告: 单纯的从TOP 5 event,基本上是看不出任何东西的,可能有人会 ...