#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
int N, A, B, used[100], rings[100], G[100][199];
int rec(int pos)
{
	int ret = 1; used[pos] = 1;
	for(int i = 0; i < rings[pos]; i++)
	{
		if(!used[G[pos][i]])
		{
			ret = max(ret, rec(G[pos][i]) + 1);
		}
	}
	used[pos] = 0;
	return ret;
}
int main()
{
	int N, A, B;
	while(true)
	{
		scanf("%d", &N);
 
		if(N == 0) { break; }
		memset(used, 0, sizeof(used));
		memset(rings, 0, sizeof(rings));
		for(int i = 0; i < N; i++)
		{
			scanf("%d", &A); A--;
			scanf("%d", &B); B--;
			G[A][rings[A]] = B; rings[A]++;
			G[B][rings[B]] = A; rings[B]++;
		}
		int nodes = 0;
		for(int i = 0; i < 100; i++)
		{
			if(rings[i])
			{
				nodes++;
			}
		}
		int ret = 0;
		for(int i = 0; i < 100; i++)
		{
			ret = max(ret, rec(i));
 			if(ret == nodes) break;
		}
 
		printf("%d\n", ret);
	}
	return 0;
}