线性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;
}
相关推荐
To_OC8 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵12 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC14 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent