【1】P10741 [SEERC 2020] Fence Job【动态规划】
其实这是一道好题。首先考虑数据范围提示您
类似题目:AGC058B。
#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;
}