#include<cstring>
#include<iostream>
#include<cstdio>
using namespace std;
const int MAX = 0x3f3f3f3f;
const int MAXN = 100 + 10;
int _map[MAXN][MAXN];
int dis[MAXN];
bool tag[MAXN];
int n;
void prim()
{
int ans = 0;
memset(tag,0,sizeof(tag));
for(int i = 1; i <= n; ++i)
{
dis[i] = _map[1][i];
}
tag[1] = 1;
for(int i = 1; i <= n - 1; ++i)
{
int now = MAX;
int _min = MAX;
for(int j = 1; j <= n; ++j)
{
if(!tag[j] && dis[j] < _min)
{
now = j;
_min = dis[j];
}
}
if(now == MAX)
{
cout << "?" << endl;
return ;
}
tag[now] = 1;
ans += _min;
for(int j = 1; j <= n; ++j)
{
if(!tag[j] && dis[j] > _map[now][j])
{
dis[j] = _map[now][j];
}
}
}
cout << ans << endl;
return ;
}
int main()
{
ios::sync_with_stdio(false);
while(cin >> n)
{
for(int i = 1; i <= n ; ++i)
{
for(int j = 1; j <= n ; ++j)
{
cin >> _map[i][j];
}
}
prim();
}
return 0;
}