传送门

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. RocketMQ(1)-架构原理

    RocketMQ(1)-架构原理 RocketMQ是阿里开源的分布式消息中间件,跟其它中间件相比,RocketMQ的特点是纯JAVA实现:集群和HA实现相对简单:在发生宕机和其它故障时消息丢失率更低. ...

  2. Libra 加密稳定币:Facebook的"野心"?

    2008年11月1日,有一个传说叫中本聪的日裔美国人,发表了一篇名为<比特币:一种点对点式的电子现金系统>的论文.2009年,比特币出世,从此开启了电子货币这个收割机器,全世界的韭菜都是一 ...

  3. 使用Visual Studio Code进行MicroPython编程

    转载请注明文章来源,更多教程可自助参考docs.tpyboard.com,QQ技术交流群:157816561,公众号:MicroPython玩家汇 Visual Studio Code(以下简称VSC ...

  4. 我与微软的不解之缘 - 我的Insider Dev Tour 2019讲师之旅

    标题:我与微软的不解之缘 - 我的Insider Dev Tour 2019讲师之旅 作者:Lamond Lu 大家好,我是陆楠,来自北京盛安德青岛分公司,今年非常有幸作为讲师参加了微软Insider ...

  5. linux下用户权限划分

    场景: 建立一个目录为/devcode,该目录是给开发组用的,也就是只有开发组用户才能进行操作该目录.该组下有成员zhangsan,lisi  步骤: 1.创建用户组,命名dev groupadd d ...

  6. centos7 中安装 htop

    首先启用 EPEL Repository: yum install -y epel-release 启用 EPEL Repository 后, 可以用 yum 直接安裝 Htop: yum insta ...

  7. Navicat for MySQ v11-v12都有的,供大家学习提升使用

    Navicat for MySQL破解版是一套专为 MySQL 设计的高性能数据库管理及开发工具,Navicat for MySQL破解版主要功能包括SQL创建工具或编辑器.数据模型工具.数据传输.导 ...

  8. 源码阅读 - java.util.concurrent (三)ConcurrentHashMap

    在java.util.concurrent包中提供了一个线程安全版本的Map类型数据结构:ConcurrentMap.本篇文章主要关注ConcurrentMap接口以及它的Hash版本的实现Concu ...

  9. Python之Pandas库学习(二):数据读写

    1. I/O API工具 读取函数 写入函数 read_csv to_csv read_excel to_excel read_hdf to_hdf read_sql to_sql read_json ...

  10. java 学习之路第一节

    一.安装mysql驱动:http://mvnrepository.com/search?q=mysql-conn 二.看数据库中有什么表安装:navicat for MySQL 文件类写数据库查询: ...