牛客网暑期ACM多校训练营(第一场):E-Removal(DP)
链接:E-Removal
题意:给出序列 s1, s2, ..., sn ,1<=s[i]<=10。问删除m个数后,有多少种不同的序列。
题解:定义dp[i][j]代表长度为i,最末尾的数字为j的子序列方案数,sum[i]代表长度为i的子序列个数。
sum[0] = 1。
从 1 ~ n 遍历序列,当遍历到 s[i] 时 sum[1] ~ sum[i] 就会增加一些以 s[i] 结尾的情况。状态转移:sum[j] += (sum[j-1] - dp[j][s[i]]) % mod。多增加的情况就是 sum[j-1] 后面在增加一个 s[i] ,但是如果以 s[i] 结尾的序列以前就出现过,那么新增加的情况中就会有 dp[j][s[i]] 个重复的情况,减去即可。dp[j][s[i]] = sum[j-1],因为结尾是 s[i] 已经定了,能变得就只剩下前面 j-1 个了。
#include <bits/stdc++.h>
using namespace std; const double EPS = 1e-;
const int INF = 0x3f3f3f3f;
const int mod = 1e9 + ;
const int maxn = 1e5 + ;
int n, m, k;
int s[maxn];
long long dp[maxn][];
long long sum[maxn]; int main()
{
while(scanf("%d%d%d", &n, &m, &k) != EOF){
for(int i = ; i <= n; i++) scanf("%d", &s[i]); memset(dp, , sizeof(dp));
memset(sum, , sizeof(sum)); sum[] = ;
for(int i = ; i <= n; i++){
for(int j = i; j >= && j >= i - m; j--){
sum[j] += (sum[j-] - dp[j][s[i]]) % mod;
dp[j][s[i]] = sum[j-];
}
} printf("%lld\n", (sum[n-m] % mod + mod) % mod);
} return ;
}
牛客网暑期ACM多校训练营(第一场):E-Removal(DP)的更多相关文章
- 牛客网暑期ACM多校训练营 第九场
		
HPrefix Sum study from : https://blog.csdn.net/mitsuha_/article/details/81774727 k较小.分离x和k. 另外的可能:求a ...
 - 牛客网暑期ACM多校训练营(第四场):A Ternary String(欧拉降幂)
		
链接:牛客网暑期ACM多校训练营(第四场):A Ternary String 题意:给出一段数列 s,只包含 0.1.2 三种数.每秒在每个 2 后面会插入一个 1 ,每个 1 后面会插入一个 0,之 ...
 - 牛客网暑期ACM多校训练营(第五场):F - take
		
链接:牛客网暑期ACM多校训练营(第五场):F - take 题意: Kanade有n个盒子,第i个盒子有p [i]概率有一个d [i]大小的钻石. 起初,Kanade有一颗0号钻石.她将从第1到第n ...
 - 牛客网 暑期ACM多校训练营(第二场)A.run-动态规划 or 递推?
		
牛客网暑期ACM多校训练营(第二场) 水博客. A.run 题意就是一个人一秒可以走1步或者跑K步,不能连续跑2秒,他从0开始移动,移动到[L,R]的某一点就可以结束.问一共有多少种移动的方式. 个人 ...
 - 牛客网 暑期ACM多校训练营(第一场)A.Monotonic Matrix-矩阵转化为格子路径的非降路径计数,Lindström-Gessel-Viennot引理-组合数学
		
牛客网暑期ACM多校训练营(第一场) A.Monotonic Matrix 这个题就是给你一个n*m的矩阵,往里面填{0,1,2}这三种数,要求是Ai,j⩽Ai+1,j,Ai,j⩽Ai,j+1 ,问你 ...
 - 牛客网暑期ACM多校训练营(第三场)H  Diff-prime Pairs (贡献)
		
牛客网暑期ACM多校训练营(第三场)H Diff-prime Pairs (贡献) 链接:https://ac.nowcoder.com/acm/contest/141/H来源:牛客网 Eddy ha ...
 - 2018牛客网暑期ACM多校训练营(第二场)I- car  ( 思维)
		
2018牛客网暑期ACM多校训练营(第二场)I- car 链接:https://ac.nowcoder.com/acm/contest/140/I来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 ...
 - 牛客网暑期ACM多校训练营(第七场)Bit Compression
		
链接:https://www.nowcoder.com/acm/contest/145/C 来源:牛客网 题目描述 A binary string s of length N = 2n is give ...
 - 牛客网暑期ACM多校训练营(第一场) - J Different Integers(线段数组or莫队)
		
链接:https://www.nowcoder.com/acm/contest/139/J来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 524288K,其他语言1048 ...
 - 牛客网暑期ACM多校训练营(第九场) A题  FWT
		
链接:https://www.nowcoder.com/acm/contest/147/A来源:牛客网 Niuniu has recently learned how to use Gaussian ...
 
随机推荐
- 字符型设备驱动程序-first-printf以及点亮LED灯(二)
			
编译这几个函数之前要学一下:Linux 的几个操作命令. 学习地址:http://edu.51cto.com/lesson/id-101824.html 重要的命令 有4个 :分别是 1.lsmod, ...
 - gem install redis安装时报错:redis requires Ruby version >= 2.2.2
			
Centos默认支持ruby到2.0.0,可gem 安装redis需要最低是2.2.2 解决办法是 先安装rvm,再把ruby版本提升至2.3.3 1.安装curl sudo yum install ...
 - Android程序项目结构(二)
			
利用Android Studio创建完第一个Hello World项目后,我们会看到使用project模式的项目结构. 一..gradle和.idea 这两个目录放置的是Android Studio自 ...
 - Oracle数据库对表基本的操作--增删查改
			
--向student表中加入入学时间属性,其数据类型为日期型alter table student add scome date; --删除student表中的入学时间属性alter table st ...
 - Web | JavaScript的引用数据类型强制转换类型
			
我在这里主要的想提下的是JavaScript中的引用类型进行强制转换类型.因为对于基本数据类型的变换大多都是雷同的,很容易熟知,但是引用数据类型有一点小插曲. JavaScript的引用类型主要为对象 ...
 - zabbix3.0通过yum安装笔记
			
zabbix3.0通过yum安装笔记 一.通过yum安装zabbix rpm -Uvh https://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix- ...
 - MySQL更新丢失
			
MySQL多主结构(比如: MGR Multi Master模式),如果多主都可以写的话,很有可能出现更新丢失的情况. 定义: T1时间,T2时间,T3时间 定义: 事务A, 事务B Node1节 ...
 - php 面试常问  基础知识
			
字符串都是海针 数组是针海 输出及打印 echo 8%(-2); //输出结果为0 模后的正负号可无视 模前的有用 echo date('Y-m-d H:i:s',strtotime('-1 day' ...
 - SDR软件无线电知识要点(一)噪声系数与噪声因子
			
SDR软件无线电知识要点(一)噪声系数与噪声因子 信号质量如何评估 Noise Figure (NF) or sensitivity and Error Vector Magnitude (EVM) ...
 - vs2013发布网站合并程序是出错(ILmerge.merge:error)
			
Vs2013发布网站时,生成错误提示: 合并程序集时出错: ILMerge.Merge: ERROR!!: Duplicate type 'manage_ForcePasswrod' found in ...