贪心: Problem - C - Codeforces

思维: Problem - D - Codeforces

这两个题不错, 第一个需要考虑后面,就先标记完, 从前遍历挨个除去标记

第二个需要考虑前面, 就开始初始化为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, 巧妙标记的更多相关文章

  1. Codeforces Round #767 (Div. 2)——B. GCD Arrays

    B. GCD Arrays 题源:https://codeforces.com/contest/1629/problem/B 题目大意 给出一段区间[l, r],可以进行操作(把任意两个数拿出来,把他 ...

  2. 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 ...

  3. 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 ...

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

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

  5. Codeforces Round #535 (Div. 3) 题解

    Codeforces Round #535 (Div. 3) 题目总链接:https://codeforces.com/contest/1108 太懒了啊~好久之前的我现在才更新,赶紧补上吧,不能漏掉 ...

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

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

  7. map Codeforces Round #Pi (Div. 2) C. Geometric Progression

    题目传送门 /* 题意:问选出3个数成等比数列有多少种选法 map:c1记录是第二个数或第三个数的选法,c2表示所有数字出现的次数.别人的代码很短,思维巧妙 */ /***************** ...

  8. Codeforces Round #499 (Div. 1)

    Codeforces Round #499 (Div. 1) https://codeforces.com/contest/1010 为啥我\(\rm Div.1\)能\(A4\)题还是\(\rm s ...

  9. Codeforces Round #577 (Div. 2) D. Treasure Hunting

    Codeforces Round #577 (Div. 2)  D. Treasure Hunting 这个一场div2 前面三题特别简单,这个D题的dp还是比较难的,不过题目告诉你了只能往上走,所以 ...

随机推荐

  1. jdk源码阅读笔记

    1.环境搭建 http://www.komorebishao.com/2020/idea-java-jdk-funyard/ 2. 好的源码阅读资源 https://zhuanlan.zhihu.co ...

  2. 同一套代码部署多个实例来并行完成mysql某项任务,且避免重复执行

    我经常会碰到一些耗时较长的任务,譬如更新5千万条表数据中的某个字段,代码中可以通过分页依次读取db,然后更新即可.但是耗时极长,那么能否通过将代码部署多个实例,譬如启动多个docker来并行执行任务, ...

  3. lombok的@builder 不能新建DO对象 Lombok存在的一些问题

    1. 实体类加上 lombok的@builder之后  就不能新建对象了,,,构造函数被覆盖了? 加上两个标签之后解决 2.Lombok存在的一些问题 lombok问题 @Builder和@NoArg ...

  4. Mapper 编写有哪几种方式?

    第一种:接口实现类继承 SqlSessionDaoSupport:使用此种方法需要编写 mapper 接口,mapper 接口实现类.mapper.xml 文件. 1.在 sqlMapConfig.x ...

  5. MySQL 根据JSON类型的字段进行过滤数据的方式

    第一种方式:JSON_CONTAINS 函数 : 执行相等形式的比较 注意:值的类型一定要相同,不然会报错 文档地址:https://dev.mysql.com/doc/refman/8.0/en/j ...

  6. 在chrome浏览器英文环境下为什么上面现行代码不起作用?

    因为后面的客户端区域会覆盖前面的用户区域所以上面现行代码不起作用

  7. zookeeper 的应用

    不建议使用(单独)zookeeper 做分布式队列,有几点原因,以下原因摘抄于curator的官网: 1.zookeeper有1MB的传输限制.而在队列中,拥有很多的数据节点,通常包括数千个,如果有较 ...

  8. 学习MFS(一)

    MFS概述 MooseFS,是一个具备冗余容错功能的分布式网络文件系统,它将数据分别存放在多个物理server或单独disk或partition上,确保一份数据有多个备份副本,对于访问MFS的clie ...

  9. Linux中redis的redis.conf文件的移动

    Linux中启动redis的过程我想大家都会,但是正常使用redis包目录下启动redis时会出现以下页面: 那么此时只有按ctrl + c退出redis才能使用命令行输入别的命令,这种有点不方便. ...

  10. Effective Java —— 消除过期的对象引用

    本文参考 本篇文章参考自<Effective Java>第三版第七条"Eliminate obsolete object references" Memory leak ...