注意要求的是最长递增子串,不是子序列,由于要求连续,所以只需要看是否比前一个数大
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>
using namespace std;
int dp[100050];
int a[100050];
int main()
{
int n,M=1;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
dp[i]=1;
}
for(int i=0;i<n;i++)
{
if(a[i]>a[i-1]) dp[i]=dp[i-1]+1;
M=max(M,dp[i]);
}
printf("%d\n",M);
return 0;
}