#include<bits/stdc++.h>
using namespace std;
int x,n,maxx,m,a[100001],b[100001],h[100001],k,j,i=1;
int main(){
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(h,0,sizeof(h));
while(cin>>a[i]){
maxx=0;
for(j=1;j<=i-1;j++)
if(b[j]>=a[i])
if(b[j]>maxx)
maxx=b[j];
b[i]=maxx+1;
if(b[i]>m)
m=b[i];
x=0;
for(k=1;k<=n;k++)
if(h[k]>=a[i]){
if(x==0)
x=k;
}
else if(x==0){n++;x=n;}
h[x]=a[i];
i++;
}
cout<<m<<endl<<n<<endl;
return 0;
}