#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,x,y,v;
int f[101][101][101][101];
int a[101][101];
int main()
{
scanf("%d",&n);
while (true)
{
scanf("%d%d%d",&x,&y,&v);
if(x==0) break;
a[x][y]=v;
}//输入
for(int x1=1;x1<=n;x1++)
for(int y1=1;y1<=n;y1++)
for(int x2=1;x2<=n;x2++)
for(int y2=1;y2<=n;y2++)
{
f[x1][y1][x2][y2]=max(max(f[x1-1][y1][x2-1][y2],f[x1-1][y1][x2][y2-1]),max(f[x1][y1-1][x2-1][y2],f[x1][y1-1][x2][y2-1]))+a[x1][y1]+a[x2][y2];
if(x1==x2&&y1==y2) //x1,y1控制前一条路径 x2,y2控制后一条路径
f[x1][y1][x2][y2]-=a[x1][y1];//若两条路径的数值相同,说明其为同一条路径,其数值只能加一遍
}//输出两条路径的和
int ans=f[n][n][n][n];
printf("%d",ans);
return 0;
}