codeforce..Remove One Element

题意:
可以删去一个数,找出最长的上升子序列

思路:
dp。用0行的dp数组记录当前位置为末尾的最大上升子序列的长度,用1行的dp数组记录当前位置为开始的最大上升子序列的长度。然后我们从前遍历一次,取当前位置为首的最大长度,加上去掉当前点前后两段加和的最大长度,取最大值,遍历之后即为答案。

代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<vector>
#include<set>
#include<string>
#include<cmath>
#include<cstring>
#define ll long long
#define pb push_back
#define pm make_pair
using namespace std;
const int MAX = 2e5 + 10;
const int inf = 0x3f3f3f3f;
int arr[MAX];
int dp[2][MAX];
int main()
{
	int n , ans = 0;
	cin >> n;
	for(int i = 1 ; i <= n ; i++)
	{
		cin >> arr[i];
		if(arr[i]>arr[i-1])
		  dp[0][i] = dp[0][i-1]+1;
		else
		  dp[0][i] = 1;
	}
	for(int i = n ; i > 0 ; i--)
	{
		if(arr[i+1] > arr[i])
		  dp[1][i] = dp[1][i+1]+1;
		else
		  dp[1][i] = 1;
	}
	for(int i = 1 ; i <= n ; i++)
	{
		ans = max(ans,dp[1][i]);
		if(arr[i-1] < arr[i+1])
		  ans = max(ans,dp[0][i-1]+dp[1][i+1]);
	}
	cout << ans << endl;
	return 0;
}
发布了124 篇原创文章 · 获赞 4 · 访问量 9112
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览