题意:
可以删去一个数,找出最长的上升子序列
思路:
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;
}