把博客园图标替换成自己的图标
把博客园图标替换成自己的图标end

【前缀和优化dp】ABC179 D Leaping Tak

题目链接

题目解析

其实是一道水题,但我还是想了好久(指40min+

首先可以搞一个一般的dp出来:定义f[i]表示走到i的方案数

那么有转移:f[i]+=f[id],dS

这个转移的复杂度消耗是巨大的,但是由于k比较小,而且符合条件的转移对象是连续的,所以可以用前缀和优化。

定义s[i]=f[1]+f[2]+...+f[i]

于是有:f[i]+=s[iLj]s[iRj1]

复杂度O(nk)


►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;
}

posted @   Starlight_Glimmer  阅读(179)  评论(0编辑  收藏  举报
编辑推荐:
· 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考试策略
浏览器标题切换
浏览器标题切换end
点击右上角即可分享
微信分享提示