P5204 [USACO19JAN]Train Tracking 2
P5204 [USACO19JAN]Train Tracking 2
毒毒题,对着嘤文题解看了贼久
首先考虑此题的一个弱化版本:如果输入的所有\(c_i\)相等怎么做
现在假设有\(len\)个数,取值从\(v\)到\(10^9\),而且每连续\(k\)个数至少有一个是\(v\)
那么取值就只有\(v\)和\(>v\)两种取值了,\(>v\)的取值有\(10^9-v\)种,设为\(x\)
那么有一个显然的dp,\(f_i\)表示这个问题i个数的答案
枚举这个数列的最后一个取值为\(v\)的数,假设是第\(j\)个,那么后面的\(i-j\)个数有\(x\)种选法
\(f_i=\sum_{j=i-k+1}^{i}x^{i-j}f_{j-1}\)
这个dp显然是不行的,还有一个dp,也是设\(f_i\)表示这个问题i个数的答案
\(f_i=(x+1)f_{i-1}-x^kf_{i-k-1}\)
第\(i\)个数随便选,乘\(i-1\)个数的答案,这时可能出现问题,就是第\(i-k+1\)个数到第\(i\)个数都\(>v\)导致了不合法,所以要减掉这些情况
为什么减掉的是\(x^kf_{i-k-1}\)呢,显然这\(k\)个数的放法共\(x^k\)种没有问题,要注意一下从第\(i-k+1\)个数到第\(i-1\)个数都\(>v\),那么只有第\(i-k\)个数取值是\(v\)才能够满足最小值的条件,所以前面的取值方案数是\(f_{i-k-1}\)
il int solve(int v,int len){
int x=1000000000-v,xk=pow(x,k);
f[0]=f[1]=1;
for(int i=2;i<=len+1;++i){
f[i]=1ll*(x+1)*f[i-1]%mod;
if(i-k-1>=0)f[i]=(f[i]-1ll*xk*f[i-k-1]%mod+mod)%mod;
}
return f[len+1];
}
那么解决了前面的问题,后面的也很好办
设\(s(v,len)\)表示现在假设有\(len\)个数,取值从\(v\)到\(10^9\),而且每连续\(k\)个数至少有一个是\(v\)问题的答案,可以在\(O(len)\)时间内球解
首先,可以将一段相等的\(c\)合并起来
然后(开始口胡)
对于一个段\(c_i=\cdots=c_j\),如果只有这一段,方案数为\(s(c_i,j-i+k)\)
如果有一个\(c_{i-1}>c_i\)
那么可以知道的是
\(\min\{a_{i-1},\cdots,a_{i+k-2}\}=c_{i-1}\)
这里可以推出\(a_{i-1},\cdots,a_{i+k-2}\geq c_{i-1}\)
\(\min\{a_{i},\cdots,a_{i+k-1}\}=c_{i}\)
前面已经推出\(a_{i},\cdots,a_{i+k-2}\geq c_{i-1}>c_{i}\)了,所以这些都不可能是最小值
这一段的最小值只能有一个就是\(a_{i+k-1}=c_{i}\)
前面的数也都在前一段的范围内
所以这一段最前面\(k\)个数就没了,其中前\(k-1\)个数会在前面段计算答案,第\(k\)个数只有一个取值\(c_i\)
对于后面也同理,如果\(c_{j+1}>c_j\)则后面\(k\)个数没了
所以一段的len实际上是\(j-i+k\)减去0到2个\(k\)
对于所有的段依次球解最后方案数乘起来即可
代码极为简单
#include<bits/stdc++.h>
#define il inline
#define vd void
#define mod 1000000007
typedef long long ll;
il ll gi(){
ll x=0,f=1;
char ch=getchar();
while(!isdigit(ch)){
if(ch=='-')f=-1;
ch=getchar();
}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
int n,k;
int a[100010];
int f[100010];
il int pow(int x,int y){
int ret=1;
while(y){
if(y&1)ret=1ll*ret*x%mod;
x=1ll*x*x%mod;y>>=1;
}
return ret;
}
il int solve(int v,int len){
int x=1000000000-v,xk=pow(x,k);
f[0]=f[1]=1;
for(int i=2;i<=len+1;++i){
f[i]=1ll*(x+1)*f[i-1]%mod;
if(i-k-1>=0)f[i]=(f[i]-1ll*xk*f[i-k-1]%mod+mod)%mod;
}
return f[len+1];
}
int main(){
#ifndef ONLINE_JUDGE
freopen("in.in","r",stdin);
freopen("out.out","w",stdout);
#endif
n=gi(),k=gi();
for(int i=1;i<=n-k+1;++i)a[i]=gi();
int ans=1,len;
for(int i=1,j;i<=n-k+1;i=j+1){
j=i;
while(a[j+1]==a[i])++j;
len=j-i+k;
if(i!=1&&a[i-1]>a[i])len-=k;
if(j!=n-k+1&&a[j+1]>a[i])len-=k;
if(len>0)ans=1ll*ans*solve(a[i],len)%mod;
}
printf("%d\n",ans);
return 0;
}
P5204 [USACO19JAN]Train Tracking 2的更多相关文章
- [USACO19JAN]Train Tracking 2——神仙结论题+DP
原题链接 orz xzz巨佬 首先发现一个结论:两个相邻的\(c\)值如果不相同的话,就可以固定某个位置的值了 这启示我们把连续且相等的\(c\)给单独拿出来看,也就是对于一些\(c_i=c_{i+1 ...
- [USACO19JAN]Train Tracking 2 P
拿到本题后,可以观察到一个性质,如果出现了 \(c_i \ne c_{i + 1}\) 那么我们一定可以确定一个位置的值,这启示着我们将 \(c_i\) 相同的部分单独拿出来考虑再将最后的答案合并.于 ...
- [luogu5204]Train Tracking 2
考虑一个位置的上界,即$bi=min(c_{i-k+1},c_{i-k+2},--,ci)$,那么每一个位置有两种方式:1.达到上界:2.未达到上界那么可以将权值相同的ci和bi提出来,由于权值不同的 ...
- [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构
[源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 目录 [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 0x00 摘要 0x01 启动 1.1 分 ...
- [TensorBoard] Train and Test accuracy simultaneous tracking
训练时的实时状态跟踪的重要性 不言而喻. [Tensorboard] Cookbook - Tensorboard 讲解调节更新频率 直接上代码展示: import numpy as np impo ...
- (转)CVPR 2016 Visual Tracking Paper Review
CVPR 2016 Visual Tracking Paper Review 本文摘自:http://blog.csdn.net/ben_ben_niao/article/details/52072 ...
- 论文笔记之:Fully-Convolutional Siamese Networks for Object Tracking
gansh Fully-Convolutional Siamese Network for Object Tracking 摘要:任意目标的跟踪问题通常是根据一个物体的外观来构建表观模型.虽然也取得了 ...
- 论文笔记之:Learning Multi-Domain Convolutional Neural Networks for Visual Tracking
Learning Multi-Domain Convolutional Neural Networks for Visual Tracking CVPR 2016 本文提出了一种新的CNN 框架来处理 ...
- 论文笔记:Learning Attribute-Specific Representations for Visual Tracking
Learning Attribute-Specific Representations for Visual Tracking AAAI-2019 Paper:http://faculty.ucmer ...
随机推荐
- Info.plist的CFBundleIdentifier、CFBundleName、BundleDisplayName
plist关键字段: CFBundleIdentifier:应用包名.唯一标识 CFBundleVersion:文件版本号,可以每次发版本递增 CFBundleShortVersionString:a ...
- ASP.NET MVC从请求到响应发生了什么
*过程描述 当浏览器发出一个http请求后,该请求被UrlRoutingModule截获,UrlRoutingModule根据请求上下文去系统路由表(RouteTable)中匹配,从中获取一个Rout ...
- redis的一命令
参考http://redisdoc.com/ 参考http://redis.io/commands 连接操作相关的命令 默认直接连接 远程连接-h 192.168.1.20 -p 6379 ping ...
- python第三十天-类
编程范式 编程是程序员用特定的语法+数据结构+算法组成的代码来告诉计算机如何执行任务的过程 , 一个程序是程序员为了得到一个任务结果而编写的一组指令的集合,正所谓条条大路通罗马,实现一个任务的方式有很 ...
- NAudio音频文件转换
1.NuGet安装 NAudio,项目及demo的网址:https://github.com/naudio/NAudio Encode to MP3, WMA and AAC with MediaFo ...
- Asp.net webForm设置允许表单提交Html
1. 在表单需要提交Html的页面头部加入 ValidateRequest="false" <%@ Page Language="C#" AutoEve ...
- 【PAT】B1042 字符统计(20 分)
/* 15分的题很简单,但是自己写的时候在输入数据时没有考虑好下标 另外有忘记了输入字符时考虑是否有\n */ #include<stdio.h> #include<algorith ...
- Ubuntu + python pip遇到的问题
今天在做Flask跨源资源共享(CORS)的时候在安装flask-cors时遇到了两个问题. 首先我是在Ubuntu环境下安装的,整了好一会才弄得出来,现在整理一下. 安装flask-cors pip ...
- [项目实践] python文件路径引用的规则,记一次使用sys.path[0]的问题,及如何区分 ../与 ./的使用场景
下面是一个获取配置的代码 def getValue(self,section,option): """ @file: string,the name of the con ...
- 从零上手Python关键代码
来源 https://www.kesci.com/home/project/59e4331c4663f7655c499bc3