1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
   | #include <bits/stdc++.h> using namespace std; constexpr int maxn = 1010; int a[maxn], f[maxn]; int n;
  int main() {     scanf("%d", &n);     for (int i = 1; i <= n; i ++ ) scanf("%d", &a[i]);
      int res = 0;     for (int i = 1; i <= n; i ++ ) {         f[i] = 1;          for (int j = 1; j < i; j ++ )             if (a[j] < a[i])                 f[i] = max(f[i], f[j] + 1);         res = max(res, f[i]);     }     printf("%d\n", res);
      return 0; }
   |