Codeforces Round #767 (Div. 2) c d, 巧妙标记
这两个题不错, 第一个需要考虑后面,就先标记完, 从前遍历挨个除去标记
第二个需要考虑前面, 就开始初始化为0, 从前遍历挨个标记
C. Meximum Array
题意: 给出n个数, 把n个数分成任意份, 使得每一段mex结果尽量的大, 其次连起来数尽量的长
mex = 一组数最小且不存在于序列中的数, 包括0
题解: 既然要每段的mex尽量大, 那么后面加再多数 mex都不会变, 那么后面都是小于或大于mex, 即这一段序列后面没有mex
#include <bits/stdc++.h> using namespace std; const int N = 2e5+10;
int a[N], cnt[N];
bool st[N];
int main()
{
int t;
cin >> t;
while(t --)
{
vector<int> res;
int n;
cin >> n;
for(int i = 0; i < n; i ++)cnt[i]=0;
for(int i = 0; i < n; i ++)cin >> a[i], cnt[a[i]]++, st[i]=0;
/*
cnt //后面的所有数的次数, 用于判断后面还有没有更大的数
st //当前一小段序列谁出现过
*/
int mex = 0;//当前一小段序列的mex
for(int i = 0; i < n; i ++)
{
st[a[i]]=1;
while(st[mex])mex++;//找到从前到后第一个没有的数, 求mex
cnt[a[i]]--;//后面还有几个这个数
if(cnt[mex]<=0)//后面也没有这个数,那么再往后也没用了
{
res.push_back(mex);
for(int j = mex-1; j >= 0; j --)//为下一段序列初始化
{
st[j]=0;
}
mex=0;
}
}
cout << res.size() << endl;
for(int i = 0; i < res.size(); i ++)cout << res[i] << ' ';
cout << endl;
}
return 0;
}
D. Peculiar Movie Preferences
题意: 米海计划看一部电影。他只喜欢回文电影,所以他想跳过一些(可能零)场景,使电影的其余部分回文, 每个场景长度不超过三。
题解: 无非两种情况1.本身是回文2.遍历时前面有一串可以和他构成回文(从前往后遍历)
所以从前往后遍历的话, 只看它是否能够成为后缀
/*
做后缀:
倒过来加一个数
倒过来去一个数
倒过来 */
#include<bits/stdc++.h>
#define ll long long
using namespace std;
int tx[4] = {-1,0,1,0}, ty[4] = {0,1,0,-1}; typedef pair<int,int> PII; const int N = 1e5+10;
string a[N];
map<string,bool> mp; bool solve()
{
mp.clear();//map用法
int n;
cin >> n;
bool f = 0;
for(int i = 0; i <n ; i ++)
{ cin >>a[i];
mp[a[i]]=1;
string s = a[i];
reverse(s.begin(), s.end());
if(s.size()==1 || s.size()==2&&s[0]==s[1] || mp[s])f=1;//本身是回文 if(mp[s.substr(0,s.size()-1)])f=1;//倒过来去一个数 for(char i = 'a'; i <= 'z'; i ++)//倒过来加一个数
if(mp[s+i])
f= 1;
}
return f;
}
int main()
{
int t;
cin >> t;
while(t --)
{
if(solve())puts("YES");
else puts("NO");
}
}
Codeforces Round #767 (Div. 2) c d, 巧妙标记的更多相关文章
- Codeforces Round #767 (Div. 2)——B. GCD Arrays
B. GCD Arrays 题源:https://codeforces.com/contest/1629/problem/B 题目大意 给出一段区间[l, r],可以进行操作(把任意两个数拿出来,把他 ...
- Codeforces Round #260 (Div. 2) A , B , C 标记,找规律 , dp
A. Laptops time limit per test 1 second memory limit per test 256 megabytes input standard input out ...
- 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 ...
- Codeforces Round #538 (Div. 2) (A-E题解)
Codeforces Round #538 (Div. 2) 题目链接:https://codeforces.com/contest/1114 A. Got Any Grapes? 题意: 有三个人, ...
- Codeforces Round #535 (Div. 3) 题解
Codeforces Round #535 (Div. 3) 题目总链接:https://codeforces.com/contest/1108 太懒了啊~好久之前的我现在才更新,赶紧补上吧,不能漏掉 ...
- Codeforces Round #527 (Div. 3) ABCDEF题解
Codeforces Round #527 (Div. 3) 题解 题目总链接:https://codeforces.com/contest/1092 A. Uniform String 题意: 输入 ...
- map Codeforces Round #Pi (Div. 2) C. Geometric Progression
题目传送门 /* 题意:问选出3个数成等比数列有多少种选法 map:c1记录是第二个数或第三个数的选法,c2表示所有数字出现的次数.别人的代码很短,思维巧妙 */ /***************** ...
- Codeforces Round #499 (Div. 1)
Codeforces Round #499 (Div. 1) https://codeforces.com/contest/1010 为啥我\(\rm Div.1\)能\(A4\)题还是\(\rm s ...
- Codeforces Round #577 (Div. 2) D. Treasure Hunting
Codeforces Round #577 (Div. 2) D. Treasure Hunting 这个一场div2 前面三题特别简单,这个D题的dp还是比较难的,不过题目告诉你了只能往上走,所以 ...
随机推荐
- python3输出由1、2、3、4这四个数字组成的每位数都不相同的所有三位数
for i in range(1,5): for j in range(1,5): for k in range(1,5): if(i!=j and i!=k and j!=k): print(i*1 ...
- nginx配置限制同一个ip的访问频率方法
1.在nginx.conf里的http{}里加上如下代码: limit_conn_zone $binary_remote_addr zone=perip:10m; limit_conn_zone ...
- select、poll和epoll的区别
操作系统在处理io的时候,主要有两个阶段: 等待数据传到io设备 io设备将数据复制到user space 我们一般将上述过程简化理解为: 等到数据传到kernel内核space kernel内核区域 ...
- Axure7.0 以及 中文汉化语言包下载 axure汉化包
支持 Axure RP Pro 正式版 当前最新版本 7.0.0.3184 不兼容6.5及以下版本! Axure7.0 下载地址:http://pan.baidu.com/s/1dEuR8YX Axu ...
- SpringMVC解决前端传来的中文字符乱码问题
以前乱码问题通过过滤器解决,而SpringMVC给我们提供了一个过滤器,可以在web.xml中添加以下配置 修改了xml文件需要重启服务器! <!--配置解决中文乱码过滤器--> < ...
- bzoj5315/luoguP4517 [SDOI2018]战略游戏(圆方树,虚树)
bzoj5315/luoguP4517 [SDOI2018]战略游戏(圆方树,虚树) bzoj Luogu 题目描述略(太长了) 题解时间 切掉一个点,连通性变化. 上圆方树. $ \sum |S| ...
- Apache+tomcat实现应用服务器集群
Ngnix/Apache比较 Nginx:Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行.其特点是占有内存少,并发能力 ...
- 什么是BGP
BGP概述 边界网关协议(BGP)是运行于TCP协议上的一种自治系统的路由协议. 是一种外部路由协议. AS概述 自治系统(AS),指的是同一个使用相同策略的设备的集合. 每个AS有自己位移的编号,不 ...
- 为什么Java中 wait 方法需要在 synchronized 的方法中调用?
另一个棘手的核心 Java 问题,wait 和 notify.它们是在有 synchronized 标记的方法或 synchronized 块中调用的,因为 wait 和 modify 需要监视对其上 ...
- Hadoop的安装配置(一)
一.Hadoop的安装①Hadoop运行的前提是本机已经安装了JDK,配置JAVA_HOME变量②在Hadoop中启动多种不同类型的进程 例如NN,DN,RM,NM,这些进程需要进行通信 ...