/*
#include <stdio.h>
#include <stdlib.h>
int main()
{
printf("Hello world!\n");
return 0;
}
*/
/*
#include <stdio.h>
int main()
{
int h,w,n,l,d,x,y;
int i, j;
int res[101][101]={0};
scanf("%d %d",&h, &w);
scanf("%d", &n);
for (i=1; i<=n; i++)
{
scanf("%d %d %d %d",&l,&d,&x,&y);
if (d==0)
{
for (j=0; j<l; i++)
{
res[x][y+j]=1;
}
}
else if (d==1)
{
for (j=0; j<l; i++)
{
res[x+j][y]=1;
}
}
}
for (i=1; i<=h; i++)
{
for (j=1; j<=w; j++)
{
printf("%d ",res[i][j]);
}
printf("\n");
}
}
*/
/*
#include <stdio.h>
int main()
{
int i,j,k,n,x,y;
int arr[30][30]={};
int res[30][30]={};
for (i=0; i<10; i++)
{
for (j=0; j<10; j++)
{
scanf("%d",&arr[i][j]);
}
}
// for (i=0; i<10; i++)
// {
// for (j=0; j<10; j++)
// {
// printf("%d ",arr[i][j]);
//
// }
// printf("\n");
// }
x=2;
y=2;
res[x][y]=9;
while (arr[x][y+1]=2)
{
if(arr[x][y+1]=0)
{
res[x][y+1]=9;
}
else if(arr[x][y+i]=1)
{
res[x+1][y]=9;
}
else if(arr[x][y+1]=2)
{
res[x][y+1]=9;
break;
}
else if(arr[x+1][y]=2)
{
res[x][y+1]=9;
break;
}
}
for (i=0; i<10; i++)
{
for (j=0; j<10; j++)
{
printf("%d ",res[i][j]);
}
printf("\n");
}
}
*/
/*
#include <stdio.h>
int main()
{
char s[50];
scanf("%s",&s);
printf("%s",s);
}
*/
/*
#include <stdio.h>
int main()
{
char str[31];
fgets(str, 31,stdin);
printf("%s",str);
}
*/
/*
#include <stdio.h>
int main()
{
int n;
scanf("%d",&n);
printf("%dnd",n);
}
*/
#include <stdio.h>
int main()
{
int i, j, n;
scanf("%d", &n);
for (i=1; ; i*10)
{
if(n/i<1)
{
printf("%d",i-1);
}
}
}// 자릿수 문제 질문.