Codeforces Edu Round 53 A-D
A. Diverse Substring
找普遍性(特殊解即可)。
最简单的便是存在一个区间\([i, i + 1] (1 <= i < n)\),且$str[i] $ $ != str[i + 1]$,就满足题意了。
对于其他的有可能满足的序列,必须存在:
这个字母的出现次数 $ <= $ 除这个字母之外的出现次数总和。
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int N = 1010;
int n;
char str[N];
int main(){
cin >> n >> (str + 1);
for(int i = 1; i < n; i++){
if(str[i] != str[i + 1]){
printf("YES\n%c%c\n", str[i], str[i + 1]);
return 0;
}
}
puts("NO");
return 0;
}
B. Vasya and Books
设 \(dep\) 为已知取出的层数,初始化为\(0\),\(cnt[i]\)代表i数字出现的位置
每次处理一个数字\(x\):
1、若$cnt[x] <= dep $,意味着这个数已经被清理了,直接输出\(0\)即可
2、否则,则将\(x - dep\)的数全部清理。
#include <iostream>
#include <cstdio>
using namespace std;
const int N = 200010;
int n, a[N];
int main(){
scanf("%d", &n);
for(int i = 1, x; i <= n; i++)
scanf("%d", &x), a[x] = i;
int dep = 0;
for(int i = 1; i <= n; i++){
int x; scanf("%d", &x);
if(a[x] <= dep) printf("0 ");
else printf("%d ", a[x] - dep), dep = a[x];
}
return 0;
}
C. Vasya and Robot
显然,如果修改长度为\(len\)可以成功,那么修改长度$ > len$的也都可以成功。
(可以让修改的那部分不变,剩下的照搬)
满足单调性,既可二分。
可以处理前缀和,来预处理除了\([l ,l + len - 1]\)区间外另外的部分走到的部分。
因为符合交换律(先走$[1, l - 1] 与 [l + len, n] \(的路径,再走\)[l ,l + len - 1]$ 结果不变),所以一次前缀和即可完成任务。
\(check()\)函数的书写需要注意,不单单需要曼哈顿距离(即从$(nx, ny) -> (tx, ty) \(的最短路径 )\) >= len$,而且哈密尔路径的奇偶性必须和曼哈顿距离一样,否则无论怎样都到不了。
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int N = 200010;
int n, tx, ty, x[N], y[N];
char str[N];
bool inline check(int len){
for(int l = 1, r = len; r <= n; l++, r++){
int nx = x[n] - (x[r] - x[l - 1]);
int ny = y[n] - (y[r] - y[l - 1]);
int dist = abs(tx - nx) + abs(ty - ny);
if(len >= dist && (dist & 1) == (len & 1)) return true;
}
return false;
}
int main(){
scanf("%d%s%d%d", &n, str + 1, &tx, &ty);
for(int i = 1; i <= n; i++){
x[i] = x[i - 1], y[i] = y[i - 1];
if(str[i] == 'U') y[i]++;
else if(str[i] == 'D') y[i]--;
else if(str[i] == 'L') x[i]--;
else if(str[i] == 'R') x[i]++;
}
if(!check(n)) puts("-1");
else{
int l = 0, r = n;
while(l < r){
int mid = (l + r) >> 1;
if(check(mid)) r = mid;
else l = mid + 1;
}
printf("%d", r);
}
return 0;
}
D. Berland Fair
可以预处理每次\(m\)对应的买的糖果,对其取模,因为这几次的行为是相同的,可以加快速度。
存在两数\(a\)、\(b\)且吗满足\(a >= b\),则一定满足$a % b <= a / 2 $。
#include <iostream>
#include <cstdio>
using namespace std;
typedef long long LL;
const int N = 200010;
int n, a[N], cnt;
LL T, s = 2, ans = 0;
int main(){
cin >> n >> T;
for(int i = 1; i <= n; i++) scanf("%d", a + i);
while(s){
s = cnt = 0;
for(int i = 1; i <= n; i++)
if(s + a[i] <= T) s += a[i], cnt++;
ans += (T / s) * cnt;
T %= s;
}
return 0;
}
Codeforces Edu Round 53 A-D的更多相关文章
- Educational Codeforces Round 53 E. Segment Sum(数位DP)
Educational Codeforces Round 53 E. Segment Sum 题意: 问[L,R]区间内有多少个数满足:其由不超过k种数字构成. 思路: 数位DP裸题,也比较好想.由于 ...
- Educational Codeforces Round 53 (Rated for Div. 2) (前五题题解)
这场比赛没有打,后来补了一下,第五题数位dp好不容易才搞出来(我太菜啊). 比赛传送门:http://codeforces.com/contest/1073 A. Diverse Substring ...
- Codeforces Beta Round #49 (Div. 2)
Codeforces Beta Round #49 (Div. 2) http://codeforces.com/contest/53 A #include<bits/stdc++.h> ...
- Codeforces Beta Round #80 (Div. 2 Only)【ABCD】
Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...
- Codeforces Beta Round #62 题解【ABCD】
Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...
- Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】
Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...
- Codeforces Beta Round #13 C. Sequence (DP)
题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...
- CodeForces Global Round 1
CodeForces Global Round 1 CF新的比赛呢(虽然没啥区别)!这种报名的人多的比赛涨分是真的快.... 所以就写下题解吧. A. Parity 太简单了,随便模拟一下就完了. B ...
- Codeforces Global Round 1 - D. Jongmah(动态规划)
Problem Codeforces Global Round 1 - D. Jongmah Time Limit: 3000 mSec Problem Description Input Out ...
随机推荐
- Java编发编程 - 线程池的认识(二)
核心线程池的内部实现 依然参考 JDK 对线程池的支持,各个接口.相关类之间的关系: (1)对于Executors中几个创建线程池方法底层实现: // 创建固定线程数量的线程池 public sta ...
- Java web项目 Jxl 读取excel 并保存到数据库,(从eclipse上移动到tomact服务器上,之路径更改,)
最开始在eclipse中测试的时候,并没有上传到服务器上,后来发现,想要读取数据必须上传服务器然后把文件删除就可以了,服务器不可以直接读取外地的文件.用到jxl 1.上传到服务器 前端 <for ...
- kali 系列学习08-安卓逆向
可以轻松把安卓apk的源码逆向出来,逆向有什么用,比如手机apk木马,可以用于追踪黑客,详见 https://cloud.tencent.com/developer/news/179336 用2个工 ...
- bWAPP----HTML Injection - Reflected (GET)
HTML Injection - Reflected (GET) 进入界面, html标签注入 这是核心代码 1 <div id="main"> 2 3 <h1& ...
- html2image
测试没有,生产有 也就是写死的显示,配置的不显示
- 为什么TCP连接时是三次握手,而不是两次或四次?
TCP连接时有一个重要的任务就是服务端和客户端双方互相确认收发功能是否正常.图中步骤1,当客户端发起连接,服务端接收到请求,对于服务端来说,它此时知道客户端的发送功能和自己的接收功能是正常的. 图中步 ...
- FL studio系列教程(十七):FL Studio走带面板介绍
FL Studio走带面板主要是用来控制播放.录音以及调整歌曲速度的,除此之外还可以用来选择样本剪辑.下面就来详细地看一下这部分菜单. 1.样本/歌曲模式 样本/歌曲模式主要是用来切换样本和歌曲两种模 ...
- robot 如何定义用户关键字、变量
1.用户关键字,使用robot语法定义的关键字 2.系统关键字 自带的 3.资源文件,自己定义的关键字 4.变量 自己定义的关键字,需单独建一个资源文件 自己写的关键字,需写在***Keywords ...
- 这可能是项目中最实用的java8示例了,还不来看?
一.组成及特点 数据源.中间操作.终端操作 流只能使用一次 并行流 和 串行流 二.可以产生流的数据源 集合.文件 三.中间操作 字符串操作拼接joining(""),底层实现是 ...
- Java中的接口与抽象类的区别
由于随着jdk版本的更新,在jdk1.8时,接口也增强了,所以我们分别来说明一下. (1)jdk1.8之前 在jdk1.8之前,接口里面只能定义抽象方法和常量:而抽象类比普通类有一点不同,就是抽象类里 ...