这场比赛好鬼畜啊,,A题写崩了wa了4遍,心态直接爆炸,本来想弃疗了,结果发现BCD都是傻逼题。。

A. If at first you don't succeed...(容斥原理)

题目大意:

有$N$个人参加了考试,考试完成后在通过的人中,有$A$个人去了第一个酒店聚会,有$B$个人去了第二个酒店聚会,有$C$个人同时去了两个酒店聚会。

问有多少个人没有通过考试(主角没有通过考试)

Sol

小学生容斥,参加了聚会的肯定有$A+B-C$个人,用$N$减去这个数就是不合格的喽

一开始wa了4发心态爆炸然后加了一坨特判A了。。

#include<cstdio>
using namespace std;
int main() {
int A, B, C, N;
scanf("%d %d %d %d", &A, &B, &C, &N);
int no = N - (A + B - C);
if(A >= N || B >= N || C >= N || (C > A) || (C > B)) {printf("-1"); return ;}
if(no <= || no > N) {printf("-1"); return ;}
printf("%d", N - (A + B - C));
return ;
}

B. Getting an A(贪心)

题目大意:

Vasya做了$n$门实验,得分为$2-5$之间的数,他想让自己的平均成绩(总得分除以实验次数)四舍五入后为$5$,问最少需要重做几次实验

Sol

直接贪心,肯定是先重新做得分少的,先排序,枚举的时候判断一下是否已经合格就行了

#include<cstdio>
#include<algorithm>
using namespace std;
const int MAXN = 1e5 + ;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int a[MAXN];
int main() {
double N = read(), S = ;
int x = N;
for(int i = ; i <= N; i++) a[i] = read(), S += a[i];
sort(a + , a + x + );
if(S / N >= 4.5) {printf(""); return ;}
for(int i = ; i <= N; i++) {
S -= a[i]; S += ;
if(S / N >= 4.5) {
printf("%d", i); return ;
}
}
return ;
}

C. Candies(二分)

题目大意:

Vasya有$n$个糖果,在开始的时候 Vasya 选择了一个整数$k$,表示他每天会吃$k$个糖果,Petya想偷吃一部分糖果,他每天会吃当前数量的$10\%$(下去整)的糖果

注意:若Vasya应该吃糖果且不满$k$,Vasya会全吃掉。若Petya吃糖果时数量不满$10$个,则Petya不会吃糖果

输出最小的$k$,使得$Vasya$至少吃掉一半的糖果

Sol

很显然$k$有单调性,直接二分即可

因为$Petya$每次会吃掉$10\%$的糖果,因此吃糖果的过程会很快,直接模拟即可

#include<cstdio>
#include<algorithm>
#define int long long
using namespace std;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N;
bool check(int k) {
int cur = , Ansa = , Ansb = , now = N;
while(now > ) {
if(cur & ) Ansa += min(k, now), now -= min(k, now);
else Ansb += now / , now -= now / ;
cur ^= ;
}
return Ansa >= Ansb;
}
main() {
N = read();
int l = , r = N, ans = ;
check();
while(l <= r) {
int mid = l + r >> ;
if(check(mid)) r = mid - , ans = mid;
else l = mid + ;
}
printf("%I64d", ans);
}

D. Bishwock(dp)

题目大意:

Bishwock是一种特殊的棋,它的放置规则如下所示(类似于俄罗斯方块)

给出一个$2*n$的初始局面,问最多能放多少个棋(X代表此处不能放,0代表次数可以放)

Sol

rank1的代码神奇啊,学不来

我只会暴力dp,设$f[i][j]$表示到第$i$行,状态为$j$(一共四种状态)的最大值,$g[i]$表示第$i$行所有状态的最大值(对f[i][1/2/3/4]取max)

转移的时候判断一下可以从哪里转移而来

 #include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int MAXN = ;
char s1[MAXN], s2[MAXN];
int f[MAXN][], g[MAXN];
int getg(int x) {
int ans = ;
for(int i = ; i <= x; i++)
ans = max(ans, g[i]);
return ans;
}
int main() {
scanf("%s %s", s1 + , s2 + );
int N = strlen(s1 + ), ans = ;
for(int i = ; i <= N; i++) {
for(int k = ; k <= ; k++)
f[i][k] = getg(i - );
if(s1[i] == '' && s2[i] == '') {
if(s1[i - ] == '') {
f[i][] = max(f[i][], g[i - ] + );
if(s2[i - ] == '')
f[i][] = max(f[i][], f[i - ][] + );
}
if(s2[i - ] == '') {
f[i][] = max(f[i][], g[i - ] + );
if(s1[i - ] == '')
f[i][] = max(f[i][], f[i - ][] + );
}
}
if(s1[i] == '') {
if(s1[i - ] == '' && s2[i - ] == '')
f[i][] = max(f[i][], g[i - ] + );
}
if(s2[i] == '') {
if(s1[i - ] == '' && s2[i - ] == '')
f[i][] = max(f[i][], g[i - ] + );
}
for(int k = ; k <= ; k++)
g[i] = max(f[i][k], g[i]);
ans = max(ans, g[i]);
}
printf("%d", ans);
return ;
}

总结

战况惨烈。

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

  1. Codeforces Round #491 (Div. 2)

    Codeforces Round #491 (Div. 2) https://codeforces.com/contest/991 A #include<bits/stdc++.h> us ...

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

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

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

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

  4. Codeforces Round #540 (Div. 3) 部分题解

    Codeforces Round #540 (Div. 3) 题目链接:https://codeforces.com/contest/1118 题目太多啦,解释题意都花很多时间...还有事情要做,就选 ...

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. Java中的锁之乐观锁与悲观锁

    1.  分类一:乐观锁与悲观锁 a)悲观锁:认为其他线程会干扰本身线程操作,所以加锁 i.具体表现形式:synchronized关键字和lock实现类 b)乐观锁:认为没有其他线程会影响本身线程操作, ...

  2. 冒泡排序——Java实现

    一.排序思想 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 针对所有的元素重复以上的步骤, ...

  3. 正则表达式的实践demo

    正则表达式十分强大,几乎在所有框架中处处可以看到,下载框架源码仔细阅读肯定可以发现.在项目应用中也经常需要正则的帮助,举个栗子,我们常需要用到的表单验证输入....其实还有很多,不一一道出,在这里我搜 ...

  4. Django的MTV模式详解

    参考博客:https://www.cnblogs.com/yuanchenqi/articles/7629939.html 一.MVC模型 Web服务器开发领域里著名的MVC模式. 所谓MVC就是把W ...

  5. cf375D. Tree and Queries(莫队)

    题意 题目链接 给出一棵 n 个结点的树,每个结点有一个颜色 c i . 询问 q 次,每次询问以 v 结点为根的子树中,出现次数 ≥k 的颜色有多少种.树的根节点是1. Sol 想到了主席树和启发式 ...

  6. Netty-EventLoop

    1. public interface EventLoop extends EventExecutor, EventLoopGroup 2. public interface EventExecuto ...

  7. java中加密的方式概述

    加密是用一种特殊的算法改变原有的数据,使未经授权的用户即使获得了已经加密的信息,但不知其解密的方法,仍然无法了解信息的内容.     大体上分为单向加密和双向加密,双向加密又可分为对称加密和非对称加密 ...

  8. File not Found:DockForm.dcu的解决办法

    安装控件时,如果引用了dsgnintf单元,那么就会提示找不到proxy.pas 或者DockForm.dcu的错误,只需在安装控件包时添加“lib\DesignIde.dcp”即可

  9. 发送请求获取响应内容(c#)

    C#请求url,获取响应的脚本 public string ResultOfApi(string url) { //发送请求 HttpWebRequest request = null; HttpWe ...

  10. flume-ng 自定义sink消费flume source

    如何从一个已经存在的Flume source消费数据 1.下载flume wget http://www.apache.org/dist/flume/stable/apache-flume-1.5.2 ...