线性dp-LIS题目3(合唱队形)

题目链接

解题思路

题意可以理解为找 t 1 < ⋯ < t i > t i + 1 > ... > t k ( 1 ≤ i ≤ k ) t1<⋯<ti>ti+1>...>tk(1≤i≤k) t1<⋯<ti>ti+1>...>tk(1≤i≤k)。"的最长序列。我们可以从左往右扫描,存储以 t i ti ti结尾的最长上升子序列长度 d p 1 i dp1i dp1i。然后从右往左扫描,存储以 t i ti ti结尾的最长上升子序列长度 d p 2 i dp2i dp2i。之后遍历1至n,求出 n − ( d p 1 i + d p 2 i − 1 ) n-(dp1i+dp2i-1) n−(dp1i+dp2i−1)的最小值,输出答案。

AC Code

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e2+5;
int n,a[N],dp1[N],dp2[N],ans=1e9;
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		dp1[i]=1;
		for(int j=1;j<i;j++)
			if(a[i]>a[j]) dp1[i]=max(dp1[i],dp1[j]+1);
		ans=max(ans,dp1[i]);
	}
	for(int i=n;i>=1;i--){
		dp2[i]=1;
		for(int j=i+1;j<=n;j++)
			if(a[i]>a[j]) dp2[i]=max(dp2[i],dp2[j]+1);
		ans=max(ans,dp2[i]);
	}
	for(int i=1;i<=n;i++)
		ans=min(ans,n-(dp1[i]+dp2[i]-1));
	cout<<ans;
	return 0;
}
相关推荐
小六学编程1 小时前
二分查找详解:从普通二分到左右边界
算法·c/c++
wayz111 小时前
Volume:PVO(百分比成交量震荡指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
毕竟是shy哥1 小时前
PromptHash:基于亲和提示协同学习的自适应哈希检索跨模态算法
学习·算法·哈希算法
甄心爱学习1 小时前
【项目实训(个人12)】
人工智能·python·算法
团象科技1 小时前
走访近百支出海技术团队后的海外云计算资源选型实操观察
大数据·人工智能·算法
勤自省2 小时前
吴恩达机器学习课程实验:线性回归模型入门(课后实验)
人工智能·算法·机器学习·回归·线性回归
ChillCoding2 小时前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法
智者知已应修善业2 小时前
【51单片机使用IO组赋值方法实现无源蜂鸣器响时LED12亮不响时34亮】2024-3-7
c++·经验分享·笔记·算法·51单片机
珊瑚里的鱼2 小时前
【动态规划】按摩师
算法·动态规划