import sys
input = sys.stdin.readline
n = int(input())
a = list(map(int, input().split()))
dp = [1]*n
for i in range(1, n):
for j in range(i):
if a[i] > a[j]:
dp[i] = max(dp[i], dp[j]+1)
print(max(dp))
#동적계획법
import sys
input = sys.stdin.readline
n = int(input())
a = list(map(int, input().split()))
dp = [1]*n
for i in range(1, n):
for j in range(i):
if a[i] > a[j]:
dp[i] = max(dp[i], dp[j]+1)
print(max(dp))
#동적계획법