传送门

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. oracle11g安装时出现程序未找到文件解决办法

    在安装的最后可能会出现如下问题 解决办法如下 将win64_11gR2_database_2of2中的\win64_11gR2_database_2of2\database\stage\Compone ...

  2. devexpress GridView按条件给行号上色

    private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDra ...

  3. 建设DevOps统一运维监控平台,全面的系统监控 Zabbix VS Nagios VS Open-Falcon OR Prometheus

    前言 随着Devops.云计算.微服务.容器等理念的逐步落地和大力发展,机器越来越多,应用越来越多,服务越来越微,应用运行基础环境越来多样化,容器.虚拟机.物理机不一而足.面对动辄几百上千个虚拟机.容 ...

  4. 二分查找(Binary Search)的递归和非递归

    Binary Search 有时候我们也把它叫做二进制查找 是一种较为高效的再数组中查找目标元素的方法 我们可以通过递归和非递归两种方式来实现它 //非递归 public static int bin ...

  5. 基于C#的机器学习--旅行推销员问题

    我们有一个必须在n个城市之间旅行的推销员.他不在乎什么顺序.他最先或最后访问的城市除外.他唯一关心的是他会去拜访每一个人,每个城市只有一次,最后一站是他得家. 每个城市都是一个节点,每个节点通过一条边 ...

  6. kuangbin专题 专题一 简单搜索 Fliptile POJ - 3279

    题目链接:https://vjudge.net/problem/POJ-3279 题意:格子有两面,1表示黑色格子,0表示白色格子,奶牛每次可以踩一个格子,踩到的格子和它周围的上下左右格子都会翻面,也 ...

  7. linuxprobe培训第2节课笔记2019年7月6日

    使用VM虚拟机配置RHEL实验环境. 鉴于在笔记本上装过centos7,这章内容难度对我来说不是很大. 重置root管理员密码(RHCSA考题,第一题,做不出来无法进行下一步考试) e linux16 ...

  8. Java并发之线程封闭

    读者们好! 在这篇博客中,我们将探讨线程封闭是什么意思,以及我们如何实现它. 所以,让我们直接开始吧. 1. 线程封闭 大多数的并发问题仅发生在我们想要在线程之间共享可变变量或可变状态时.如果在多个线 ...

  9. 简单学习之json格式说明

    json格式说明: 1.对象是一个无序的“‘名称/值’对”集合. (1)一个对象以“{”(左括号)开始,“}”(右括号)结束. (2)每个“名称”后跟一个“:”(冒号): (3)“‘名称/值’ 对”之 ...

  10. 2019.6.21 NOIP2018提高组模拟题(二)

    1.咒语 (curse.pas/c/cpp) [题目描述] 亮亮梦到自己来到了魔法城堡,但一扇巨大的石门阻拦了他通向城堡内的路.正当他沮丧之际,突然发现门上有一处机关,机关上有一张很长的纸条.亮亮拿起 ...