import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner scanner=new Scanner(System.in);
int n=scanner.nextInt();
int a[]=new int[n+1];
for (int i = 1; i <= n; i++) {
a[i]=scanner.nextInt();
}
int dp[]=new int[n+5];//dp[i]表示以i结尾的序列,其中最长不降子序列的长度
Arrays.fill(dp, 1);//初始化dp数组,每一个元素都赋值为1
int max=1;
for (int i = 1; i <= n; i++) {
for (int j = 1; j < i; j++) {
if(a[j]<=a[i])dp[i]=Math.max(dp[i], dp[j]+1);
}
if(dp[i]>max)max=dp[i];
}
System.out.println(max);
}
}
一定要记住,最后输出的是max而不是dpp[n]



京公网安备 11010502036488号