【前缀和优化dp】ABC179 D Leaping Tak
题目解析
其实是一道水题,但我还是想了好久(指
首先可以搞一个一般的出来:定义表示走到的方案数
那么有转移:
这个转移的复杂度消耗是巨大的,但是由于比较小,而且符合条件的转移对象是连续的,所以可以用前缀和优化。
定义
于是有:
复杂度
►Code View
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
#define LL long long
#define N 200005
#define DEL 100000
#define INF 0x3f3f3f3f
#define MOD 998244353
int rd()
{
int x=0,f=1;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')f=-1; c=getchar();}
while(c>='0'&&c<='9'){x=(x<<3)+(x<<1)+(c^48); c=getchar();}
return f*x;
}
int n,k;
LL f[N],s[N];
struct node{
int l,r;
}seg[15];
int main()
{
n=rd(),k=rd();
for(int i=1;i<=k;i++)
seg[i].l=rd(),seg[i].r=rd();
f[1]=1,s[1]=1;
for(int i=2;i<=n;i++)
{
for(int j=1;j<=k;j++)
f[i]=(f[i]+s[max(i-seg[j].l,0)]-s[max(i-seg[j].r-1,0)]+MOD)%MOD;
s[i]=(s[i-1]+f[i])%MOD;
}
printf("%lld\n",f[n]);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
2019-11-15 CSP考试策略