Educational Codeforces Round 56 (Rated for Div. 2) F - Vasya and Array dp好题
dp[ i ][ j ] 表示用了前 i 个数字并且最后一个数字是 j 的方案数。
dp[ i ][ j ] = sumdp [i - 1 ][ j ], 这样的话会有不合法的方案算进去,而且不合法的方案只有 i - len + 1 到 i 这一段相同才会
出现, 所以如果 i - len + 1 到 i 可以变成一样的话要减去 sumdp[ i - len ] - dp[ i - len ][ j ]
#include<bits/stdc++.h>
#define LL long long
#define fi first
#define se second
#define mk make_pair
#define PLL pair<LL, LL>
#define PLI pair<LL, int>
#define PII pair<int, int>
#define SZ(x) ((int)x.size())
#define ull unsigned long long
#define x first
#define y second
using namespace std; const int N = 1e5 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = ;
const double eps = 1e-; int n, k, len, a[N];
int dp[N][], sum[N], cnt[N][]; inline void add(int &a, int b) {
a += b; if(a >= mod) a -= mod;
} int main() {
scanf("%d%d%d", &n, &k, &len);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
for(int i = ; i <= n; i++)
for(int j = ; j <= k; j++)
cnt[i][j] = cnt[i-][j] + (a[i]==j || a[i]==-);
sum[] = ;
for(int i = ; i <= n; i++) { if(i < len) {
if(~a[i]) {
add(dp[i][a[i]], sum[i-]);
} else {
for(int j = ; j <= k; j++)
add(dp[i][j], sum[i-]);
}
} else {
if(~a[i]) {
add(dp[i][a[i]], sum[i-]);
if(cnt[i][a[i]]-cnt[i-len][a[i]] == len) {
add(dp[i][a[i]], mod-(sum[i-len]-dp[i-len][a[i]]+mod)%mod);
} } else {
for(int j = ; j <= k; j++) {
add(dp[i][j], sum[i-]);
if(cnt[i][j]-cnt[i-len][j]==len) {
add(dp[i][j], mod-(sum[i-len]-dp[i-len][j]+mod)%mod);
}
}
}
}
for(int j = ; j <= k; j++)
add(sum[i], dp[i][j]);
}
printf("%d\n", sum[n]);
return ;
} /*
*/
Educational Codeforces Round 56 (Rated for Div. 2) F - Vasya and Array dp好题的更多相关文章
- Educational Codeforces Round 56 (Rated for Div. 2)  F. Vasya and Array
		
题意:长度为n的数组,数组中的每个元素的取值在1-k的范围内或者是-1,-1代表这个元素要自己选择一个1-k的数字去填写,然后要求填完的数组中不能出现连续长度大于len的情况,询问填空的方案数. 题解 ...
 - Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings
		
Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...
 - Educational Codeforces Round 71 (Rated for Div. 2)-F. Remainder Problem-技巧分块
		
Educational Codeforces Round 71 (Rated for Div. 2)-F. Remainder Problem-技巧分块 [Problem Description]  ...
 - Multidimensional Queries(二进制枚举+线段树+Educational Codeforces Round 56 (Rated for Div. 2))
		
题目链接: https://codeforces.com/contest/1093/problem/G 题目: 题意: 在k维空间中有n个点,每次给你两种操作,一种是将某一个点的坐标改为另一个坐标,一 ...
 - Educational Codeforces Round 56 (Rated for Div. 2) D. Beautiful Graph 【规律 && DFS】
		
传送门:http://codeforces.com/contest/1093/problem/D D. Beautiful Graph time limit per test 2 seconds me ...
 - Educational Codeforces Round 56 (Rated for Div. 2) ABCD
		
题目链接:https://codeforces.com/contest/1093 A. Dice Rolling 题意: 有一个号数为2-7的骰子,现在有一个人他想扔到几就能扔到几,现在问需要扔多少次 ...
 - Educational Codeforces Round 56 (Rated for Div. 2) D
		
给你一个无向图 以及点的个数和边 每个节点只能用1 2 3 三个数字 求相邻 两个节点和为奇数 能否构成以及有多少种构成方法 #include<bits/stdc++.h> usin ...
 - Educational Codeforces Round 56 (Rated for Div. 2)
		
涨rating啦.. 不过话说为什么有这么多数据结构题啊,难道是中国人出的? A - Dice Rolling 傻逼题,可以用一个三加一堆二或者用一堆二,那就直接.. #include<cstd ...
 - Educational Codeforces Round 56 (Rated for Div. 2) E(1093E) Intersection of Permutations (树套树,pb_ds)
		
题意和分析在之前的链接中有:https://www.cnblogs.com/pkgunboat/p/10160741.html 之前补题用三维偏序的cdq的分治A了这道题,但是感觉就算比赛再次遇到类似 ...
 
随机推荐
- python---RabbitMQ(5)消息RPC(远程过程调用)
			
服务器端: import pika #创建socket connection = pika.BlockingConnection(pika.ConnectionParameters( host='lo ...
 - linux下安装shellinabox实现web登录服务器
			
GitHub地址(含有文件下载和详细安装流程):https://github.com/shellinabox/shellinabox 这里我们使用的是redhat安装方法如下: 1.配置安装依赖环境 ...
 - linq的语法和案例
			
本篇逐一介绍linq各个关键字的用法(from,select,group,into等),本篇所有的案例都是用linqpad来完成的(官方地址:http://www.linqpad.net/),建议想学 ...
 - WebStorm 使用webpack打包(build) Vue 静态资源无法访问(路径不对)问题
			
在WebStorm中使用webpack打包 (命令npm run build) 后生成在项目的dist目录下,在浏览器打开,静态资源js.css等无法加载.因为打包时,资源使用了绝对路径. 解决: 打 ...
 - Spring boot学习总结
			
引言之前也没有深入学习过spring框架,最近SpringBoot流行起来后想补下这方面的知识,于是照着SpringBoot官网上的英文教程开始helloworld入门,踩到几个小坑,记录下学习流程. ...
 - Session详解、ASP.NET核心知识(8)
			
介绍一下Session 1.作用 Cookie是存在客户端,Session是存在服务器端,目的是一样的:保存和当前客户端相关的数据(当前网站的任何一个页面都能取到Session). 在本篇博文的姊妹篇 ...
 - CF264B Good Sequences
			
传送门 Description: 松鼠丽丝特别喜欢n个她称之为“好整数”的整数:a1,a2,……,an.(会输入) 现在,她对“好序列”很感兴趣.如果一个序列x1,x2,...,xk能够满足一下三个条 ...
 - Linux基础-swap交换分区
			
任务:对一块15G大小的硬盘进行分区,主分区为5G,扩展分区10G,一个逻辑分区5G作为swap交换分区,并激活查看新的swap分区 第一步,建立的新的SCSI硬盘,开启Linux系统前添加一块大小为 ...
 - 20155303 2016-2017-2 《Java程序设计》第九周学习总结
			
20155303 2016-2017-2 <Java程序设计>第九周学习总结 目录 学习内容总结(Linux命令) 教材学习中的问题和解决过程 代码调试中的问题和解决过程 代码托管 上周考 ...
 - 与JavaWeb有关的故事(Web请求与Java IO)
			
作为一名后端屌丝程序员,对算法.并发.性能乐此不疲.但是,随着年龄和阅历的增加,显然叶落而不知秋的心态是不太能混了.尤其是,某T面试官在明知我是后端,且明确表示对HTTP协议不太熟的情况下,强行让我解 ...