N=gets.to_i A=gets.split.map(&:to_i) dp=[0,1].map{(1..N).map{[1]*N}} (1...N).each{|d| (0...N-d).each{|l| r=l+d dpl=dp[0][l][r-1] dpr=dp[1][l+1][r] dp[0][l][r]=A[l]>=A[r]?dpl:[dpl,dpr+1].max dp[1][l][r]=A[l]<=A[r]?dpr:[dpr,dpl+1].max } } p ((0...N).map{|i|dp[0][i][N-1]}+dp[1][0]).max