DP专题训练5

1|0数组切分

在这里插入图片描述

#include<bits/stdc++.h> using namespace std; #define int long long #define endl "\n" /* 1 3 2 4 1: {1}dp[1]+=dp[0] 2: {1}{3}dp[2]+=dp[0] 3: {1}{3}{2}dp[3]+=dp[2] {1}{3,2}dp[3]+=dp[1] {1,3,2}dp[3]+=dp[0] 4: {1}{3}{2}{4}|{1}{3,2,4}|{1,3,2,4}|dp[4]+=dp[3] {1}{3,2,4}dp[4]+=dp[1] {1,2,3,4}dp[4]+=dp[0]; dp[i]表示长度为i的划分数 当[j,i]这段区间内满足连续自然数段(即mx-mi+1=i-j+1),则可以由dp[j-1]转移来 */ const int N = 1e4 + 10; const int mod = 1e9 + 7; int n; int a[N],dp[N]; void solve(){ cin >> n; dp[0] = 1; for(int i = 1; i <= n ; i ++) cin >> a[i]; for(int i = 1; i <= n ; i ++){ int mx = a[i], mn = a[i]; for(int j = i; j >= 1 ; j --){ mx = max(mx,a[j]), mn = min(mn,a[j]); if(mx - mn + 1 == i - j + 1) dp[i] = (dp[i] + dp[j-1]) % mod; } } cout << dp[n]; } signed main(){ ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); int _ = 1; //cin >> _; while(_--) solve(); return 0; }

__EOF__

本文作者xued
本文链接https://www.cnblogs.com/xdeyt/p/18140581.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   xde_yt  阅读(4)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
点击右上角即可分享
微信分享提示