专栏文章
【1】P10741 [SEERC 2020] Fence Job【动态规划】
题解参与者 1已保存评论 0
文章操作
快速查看文章及其快照的属性,并进行相关操作。
- 当前评论
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @min1m6l8
- 此快照首次捕获于
- 2025/12/01 19:05 3 个月前
- 此快照最后确认于
- 2025/12/01 19:05 3 个月前
其实这是一道好题。首先考虑数据范围提示您 轻松拿捏。然后我们考虑如何设计状态。 为操作前 个数,已经完成了 的部署的不同方案数。显然答案为 。我们考虑如何转移。你发现有这样的转移:。也就是考虑一个不操作。还有这样的转移:,表示可以使用操作扔掉 。这种转移的限制为可以拓展的区间,要不然最小值就不是 了,也就无法通过操作转移。
类似题目:AGC058B。
CPP#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int N=3e3+10;
const ll P=1e9+7;
int n;
ll f[N][N],h[N];
int main(){
cin>>n;
for(int i=1;i<=n;i++)
cin>>h[i], f[i][0]=1;
for(int i=1;i<=n;i++){
int l=i,r=i;
for(;h[l-1]>h[i];--l);
for(;h[r+1]>h[i];++r);
for(int j=1;j<=n;j++){
if(l<=j&&j<=r)
f[i][j]=(f[i-1][j]+f[i][j-1])%P;
else
f[i][j]=f[i-1][j];
}
}
cout<<f[n][n];
return 0;
}
相关推荐
评论
共 0 条评论,欢迎与作者交流。
正在加载评论...