传送门

A: Colorful Subsequence

•题意

给一个长为n的小写字母序列,从中选出字母组成子序列

问最多能组成多少种每个字母都不相同的子序列

(不同位置的相同字母也算是不同的一种)

•思路

对于每种字母有选与不选两种情况,

①如果选的话,j假设这种字母有xi种,那就有xi种选法

②如果不选的话,有不选这一种方法

那总和起来就有(xi+1)中方法

设num[i]为每种字母的个数

对于所有的字母,总的种类数就是

但是要注意全不选的这种情况,对于上述种类数-1

•代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const long long mod=1e9+;
char s[];
int Count[];
int main()
{
int n;
cin>>n;
ll ans=;
for(int i=;i<n;i++)
{
cin>>s[i];
Count[s[i]-'a']++;
}
for(int i=;i<;i++)
ans=(ans%mod*(Count[i]+)%mod)%mod;
cout<<ans-<<endl;
}

B: Reversi

•题意

有n块石头,从左往右第i块颜色为ci

现有一操作,可以进行0次或多次

选择颜色相同的两块石头,可以把这两块石头之间的石头全部变为此种颜色

问经过所有可能的操作后,最多有多少种不同的颜色序列

•思路

对于一个石头颜色序列,从左往右一次添加石头,在右边加一块石头,位置为x,颜色为xi

① 首先不挑选x,也就是x不是区间右端点,

把x放在(x-1)块石头后面,相当于前(x-1)块石头变化有ans[x-1]种,再在末尾加上第x块石头,形成ans[x-1]种序列

②挑选x,也就是x为某个区间的右端点,

如果x想成为某个区间的右端点,那就要找他前面与他颜色相同的石头,

第x块石头和他前面距离他最近的第一块石头组合形成序列,即ans[pos[x]]种。pos[x]为第x块石头前面距离他最近的第一块石头

为什么是第一块石头呢?

因为我们是从左往右一次添加的石头,加入一个颜色为col的石头,再加入其它颜色的石头,再加入col的石头,那第一块col和第二块col可以组成,

...再加入第三块col,那第三块col可以根据第二块形成的col,再形成若干种,

为什么不根据第一块col变化呢?因为在根据第二块变化时已经包括根据第一块变化了!(第二块是根据第一块变化的!)

•代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=2e5+;
const long long mod=1e9+;
#define ll long long
ll s[maxn];
ll pos[maxn];//记录每种颜色的位置,用来得到②的种数
ll ans[maxn];//第i块石头的答案 int main()
{
int n;
cin>>n;
s[]=;
for(int i=;i<=n;i++)
{
cin>>s[i];
if(i==)//加第一块的时候肯定为1
ans[i]=,pos[s[i]]=i;//记录答案和位置
else if(s[i]==s[i-])//如果相邻颜色相同的话就只有①的种类数
ans[i]=ans[i-];//因为两块之间没有石头不能变化
else
{
ans[i]=(ans[i-]+ans[flag[s[i]]]%mod)%mod;//①的种类数+②的种类数
flag[s[i]]=i;//记录位置
}
}
cout<<ans[n]<<endl;
}

UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十五场的更多相关文章

  1. UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十四场

    A.JOIOJI •传送门 [1]:BZOJ [2]:洛谷 •思路 在一个区间(L,R]内,JOI的个数是相等的,也就是R[J]-L[J]=R[O]-L[O]=R[I]-L[I], 利用前缀和的思想, ...

  2. UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十六场

    E: 飞碟解除器 •题目描述 wjyyy在玩跑跑卡丁车的时候,获得了一个飞碟解除器,这样他就可以免受飞碟的减速干扰了.飞碟解除器每秒末都会攻击一次飞碟,但每次只有p/q的概率成功攻击飞碟.当飞碟被成功 ...

  3. UPC 2019年第二阶段我要变强个人训练赛第十六场

    传送门: [1]:UPC比赛场 [2]:UPC补题场 F.gu集合(数论) •题目描述 题目描述: Dew有一个长为n的集合S. 有一天,他想选k个不同的元素出来做游戏. 但是Dew只有两只手,所以他 ...

  4. UPC 2019年第二阶段我要变强个人训练赛第六场

    传送门 A.上学路线 题目描述 小D从家到学校的道路结构是这样的:由n条东西走向和m条南北走向的道路构成了一个n*m的网格,每条道路都是单向通行的(只能从北向南,从西向东走). 已知小D的家在网格的左 ...

  5. 2019年第二阶段我要变强个人训练赛第八场 B.序列(seq)

    传送门 B.序列(seq) •题目描述 给出一个长度为n的序列a,每次对序列进行一下的某一个操作. •输入 第一行两个整数n,q表示序列长度和操作个数. 接下来一行n个数,表示序列a. 接下来q行表示 ...

  6. UPC个人训练赛第十五场(AtCoder Grand Contest 031)

    传送门: [1]:AtCoder [2]:UPC比赛场 [3]:UPC补题场 参考资料 [1]:https://www.cnblogs.com/QLU-ACM/p/11191644.html B.Re ...

  7. 备战省赛组队训练赛第十四场(UPC)

    codeforces:传送门 upc:传送门 外来题解: [1]:https://blog.csdn.net/ccsu_cat/article/details/86707446 [2]:https:/ ...

  8. 备战省赛组队训练赛第十八场(UPC)

    传送门 题解:by 青岛大学 A:https://blog.csdn.net/birdmanqin/article/details/89789424 B:https://blog.csdn.net/b ...

  9. 备战省赛组队训练赛第十六场(UPC)

    传送门 题解: by 烟台大学 (提取码:8972)

随机推荐

  1. mac下 编译php的 openssl

    编译openssl.so tar zxvf php-7.2.8.tar.gz# 进入PHP的openssl扩展模块目录cd php-7.2.8/ext/openssl/brew install ope ...

  2. 面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)

    一.概述 面向过程:根据业务逻辑从上到下写代码 函数式:将具有一些功能的代码封装到函数中,需要的时候调用即可 面向对象:对函数进行分类和封装,让开发更方便,更快捷 Java和C#只支持面型对象编程,, ...

  3. java之继承中的静态变量

    package Test; /** * Created by wangbin10 on 2018/7/9. * 我们知道静态变量属于类级别变量,对应每个类只有一份,类的所有实例共有一份,而成员变量则分 ...

  4. React性能优化之PureComponent 和 memo使用分析

    前言 关于react性能优化,在react 16这个版本,官方推出fiber,在框架层面优化了react性能上面的问题.由于这个太过于庞大,我们今天围绕子自组件更新策略,从两个及其微小的方面来谈rea ...

  5. Windows下OSGEarth的编译过程

    目录 1. 依赖 1) OpenSceneGraph 2) GDAL 3) CURL 4) GEOS 5) 其他 2. 编译 1) 设置参数 2) 配置路径 3) 生成编译 3. 参考文献 1. 依赖 ...

  6. centos7PXE和cobbler自动部署装机

    安装程序启动过程MBR:isolinux/boot.catstage2: isolinux/isolinux.bin配置文件:isolinux/isolinux.cfg 每个对应的菜单选项: 加 ...

  7. 老雷socket编程之websocket实现

    老雷socket编程之websocket实现 我们主要实现私聊和群聊两个功能,要在web端实现想微信QQ那样的即时通讯的功能,我们需要了解一下websocket.websocket是一种可以双向通讯的 ...

  8. 【linux杂记】Ubuntu查看端口使用情况

    转载地址: https://www.linuxidc.com/Linux/2016-01/127345.htm Ubuntu查看端口使用情况,使用netstat命令: 查看已经连接的服务端口(ESTA ...

  9. 使用docker启动mysql

    安装docker 查询mysql版本, docker search mysql 拉取指定版本的镜像 docker pull NAME 启动镜像, 第一次启动最少需要指定MYSQL_ROOT_PASSW ...

  10. STM32 HAL库学习系列第7篇---定时器TIM 输入捕获功能

    测量脉冲宽度或者测量频率   基本方法 1.设置TIM2 CH1为输入捕获功能:  2.设置上升沿捕获:  3.使能TIM2 CH1捕获功能:  4.捕获到上升沿后,存入capture_buf[0], ...