#include <bits/stdc++.h>
using namespace std;
ifstream fin("darb.in");
ofstream fout("darb.out");
vector <int> a[100003];
int n,v[100003],pasi[100003];
void Citire()
{
int i,x,y;
fin>>n;
for(i=1;i<n;i++)
{
fin>>x>>y;
a[x].push_back(y);
a[y].push_back(x);
}
fin.close();
}
void DFS(int k)
{
v[k]=1;
int i,j;
for(i=0;i<a[k].size();i++)
{
j=a[k][i];
if(v[j]==0) {pasi[j]=pasi[k]+1;DFS(j);}
}
}
void Rezolvare()
{
int i,p;
pasi[1]=1;
DFS(1);
p=1;
for(i=1;i<=n;i++)
if(pasi[p]<pasi[i]) p=i;
for(i=1;i<=n;i++) v[i]=pasi[i]=0;
pasi[p]=1;
DFS(p);
p=1;
for(i=1;i<=n;i++)
if(pasi[p]<pasi[i]) p=i;
fout<<pasi[p]<<"\n";
fout.close();
}
int main()
{
Citire();
Rezolvare();
return 0;
}