UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十五场
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年第二阶段我要变强个人训练赛第十五场的更多相关文章
- UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十四场
A.JOIOJI •传送门 [1]:BZOJ [2]:洛谷 •思路 在一个区间(L,R]内,JOI的个数是相等的,也就是R[J]-L[J]=R[O]-L[O]=R[I]-L[I], 利用前缀和的思想, ...
- UPC Contest RankList – 2019年第二阶段我要变强个人训练赛第十六场
E: 飞碟解除器 •题目描述 wjyyy在玩跑跑卡丁车的时候,获得了一个飞碟解除器,这样他就可以免受飞碟的减速干扰了.飞碟解除器每秒末都会攻击一次飞碟,但每次只有p/q的概率成功攻击飞碟.当飞碟被成功 ...
- UPC 2019年第二阶段我要变强个人训练赛第十六场
传送门: [1]:UPC比赛场 [2]:UPC补题场 F.gu集合(数论) •题目描述 题目描述: Dew有一个长为n的集合S. 有一天,他想选k个不同的元素出来做游戏. 但是Dew只有两只手,所以他 ...
- UPC 2019年第二阶段我要变强个人训练赛第六场
传送门 A.上学路线 题目描述 小D从家到学校的道路结构是这样的:由n条东西走向和m条南北走向的道路构成了一个n*m的网格,每条道路都是单向通行的(只能从北向南,从西向东走). 已知小D的家在网格的左 ...
- 2019年第二阶段我要变强个人训练赛第八场 B.序列(seq)
传送门 B.序列(seq) •题目描述 给出一个长度为n的序列a,每次对序列进行一下的某一个操作. •输入 第一行两个整数n,q表示序列长度和操作个数. 接下来一行n个数,表示序列a. 接下来q行表示 ...
- UPC个人训练赛第十五场(AtCoder Grand Contest 031)
传送门: [1]:AtCoder [2]:UPC比赛场 [3]:UPC补题场 参考资料 [1]:https://www.cnblogs.com/QLU-ACM/p/11191644.html B.Re ...
- 备战省赛组队训练赛第十四场(UPC)
codeforces:传送门 upc:传送门 外来题解: [1]:https://blog.csdn.net/ccsu_cat/article/details/86707446 [2]:https:/ ...
- 备战省赛组队训练赛第十八场(UPC)
传送门 题解:by 青岛大学 A:https://blog.csdn.net/birdmanqin/article/details/89789424 B:https://blog.csdn.net/b ...
- 备战省赛组队训练赛第十六场(UPC)
传送门 题解: by 烟台大学 (提取码:8972)
随机推荐
- 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 ...
- 面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)
一.概述 面向过程:根据业务逻辑从上到下写代码 函数式:将具有一些功能的代码封装到函数中,需要的时候调用即可 面向对象:对函数进行分类和封装,让开发更方便,更快捷 Java和C#只支持面型对象编程,, ...
- java之继承中的静态变量
package Test; /** * Created by wangbin10 on 2018/7/9. * 我们知道静态变量属于类级别变量,对应每个类只有一份,类的所有实例共有一份,而成员变量则分 ...
- React性能优化之PureComponent 和 memo使用分析
前言 关于react性能优化,在react 16这个版本,官方推出fiber,在框架层面优化了react性能上面的问题.由于这个太过于庞大,我们今天围绕子自组件更新策略,从两个及其微小的方面来谈rea ...
- Windows下OSGEarth的编译过程
目录 1. 依赖 1) OpenSceneGraph 2) GDAL 3) CURL 4) GEOS 5) 其他 2. 编译 1) 设置参数 2) 配置路径 3) 生成编译 3. 参考文献 1. 依赖 ...
- centos7PXE和cobbler自动部署装机
安装程序启动过程MBR:isolinux/boot.catstage2: isolinux/isolinux.bin配置文件:isolinux/isolinux.cfg 每个对应的菜单选项: 加 ...
- 老雷socket编程之websocket实现
老雷socket编程之websocket实现 我们主要实现私聊和群聊两个功能,要在web端实现想微信QQ那样的即时通讯的功能,我们需要了解一下websocket.websocket是一种可以双向通讯的 ...
- 【linux杂记】Ubuntu查看端口使用情况
转载地址: https://www.linuxidc.com/Linux/2016-01/127345.htm Ubuntu查看端口使用情况,使用netstat命令: 查看已经连接的服务端口(ESTA ...
- 使用docker启动mysql
安装docker 查询mysql版本, docker search mysql 拉取指定版本的镜像 docker pull NAME 启动镜像, 第一次启动最少需要指定MYSQL_ROOT_PASSW ...
- STM32 HAL库学习系列第7篇---定时器TIM 输入捕获功能
测量脉冲宽度或者测量频率 基本方法 1.设置TIM2 CH1为输入捕获功能: 2.设置上升沿捕获: 3.使能TIM2 CH1捕获功能: 4.捕获到上升沿后,存入capture_buf[0], ...

