洛谷 P3205 [HNOI2010] 合唱队

思路

先设 d p [ i ] [ j ] dp[i][j] dp[i][j] 为区间 [ i , j ] [i, j] [i,j] 的队形方案数。

考虑如何转移:对于区间 [ i , j ] [i, j] [i,j] 来说,最后一个入队的要么是 i i i,要么是 j j j。

所以分类讨论:

  1. 当 j j j 为最后一个入队的时, i i i 与 j − 1 j - 1 j−1 都可能是倒数第二个入队的。要满足的条件分别是 h [ i ] < h [ j ] h[i] < h[j] h[i]<h[j] 和 h [ j − 1 ] < h [ i ] h[j - 1] < h[i] h[j−1]<h[i]。
  2. 当 i i i 为最后一个入队的时, j j j 与 i + 1 i + 1 i+1 都可能是倒数第二个入队的。要满足的条件分别是 h [ i ] < h [ j ] h[i] < h[j] h[i]<h[j] 和 h [ i ] < h [ i + 1 ] h[i] < h[i + 1] h[i]<h[i+1]。

发现上一个状态有两种,即:在上一个状态中,最后一个进来的数(也就是当前状态的倒数第二个进来的数)是在【队尾/队头】。

因此我们要丰富一下状态定义:设 d p [ i ] [ j ] [ 0 ] dp[i][j][0] dp[i][j][0] 表示最后一个进来的数在【队头】的方案数, d p [ i ] [ j ] [ 1 ] dp[i][j][1] dp[i][j][1] 表示最后一个进来的数在【队尾】的方案数。最后答案就是 d p [ 1 ] [ n ] [ 0 ] + d p [ 1 ] [ n ] [ 1 ] dp[1][n][0] + dp[1][n][1] dp[1][n][0]+dp[1][n][1]。

代码

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int maxn = 1e3 + 7;
const int mod  = 19650827;

int n, a[maxn];
int dp[maxn][maxn][2];
int main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; ++i)
	    scanf("%d", a + i), 
		dp[i][i][0] = 1;

	for (int len = 2; len <= n; ++len) {
		for (int i = 1; i + len - 1 <= n; ++i) {
			int j = i + len - 1;
			
			if (a[i] < a[j]) dp[i][j][1] = (dp[i][j][1] + dp[i][j - 1][0]) % mod;
			if (a[j - 1] < a[j]) dp[i][j][1] = (dp[i][j][1] + dp[i][j - 1][1]) % mod;
		    
		    if (a[i] < a[j]) dp[i][j][0] = (dp[i][j][0] + dp[i + 1][j][1]) % mod;
			if (a[i] < a[i + 1]) dp[i][j][0] = (dp[i][j][0] + dp[i + 1][j][0]) % mod;
		}
	}
	printf("%d\n", (dp[1][n][0] + dp[1][n][1]) % mod);
	return 0;
} 
相关推荐
故事和你9110 小时前
洛谷-【图论2-1】树4
开发语言·数据结构·c++·算法·动态规划·图论
故事和你9110 小时前
洛谷-【图论2-1】树1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
木子墨51618 小时前
工程算法实战 | 数据库ORDER BY的底层:内存排序 → 外部归并 → 索引优化
数据结构·数据库·python·sql·算法·动态规划
The Chosen One98518 小时前
分享对dp题目的理解-不断更新ing
笔记·算法·深度优先·动态规划·dp
玛卡巴卡ldf19 小时前
【LeetCode 手撕算法】(动态规划)爬楼梯、杨辉三角、打家劫舍、完全平方数、零钱兑换、单词拆分、最长递增子序列、乘积最大子数组、分割等和子集
java·数据结构·算法·leetcode·动态规划·力扣
焜昱错眩..2 天前
力扣周赛难题 3906.统计网格路径中好整数的数目——自我拆解学习与分析(数位dp上下界的奇妙)
学习·算法·leetcode·动态规划
故事和你912 天前
洛谷-【图论2-1】树2
开发语言·数据结构·c++·算法·动态规划·图论
云栖梦泽在2 天前
AI安全入门:AI模型泄露的风险与防护措施
人工智能·算法·动态规划
zB6822HbX3 天前
狙击模拟《Center Mass: Streets of Ramadi》Steam页面 发售日待定
贪心算法·排序算法·动态规划
落羽的落羽3 天前
【算法札记】练习 | Week3
linux·服务器·数据结构·c++·人工智能·算法·动态规划