#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 600;
//const int MOD = 998244353;
ll dp[N][N];
int main(){
int n; cin >> n;
for(int i = 1 ; i <= n ; i++){
for(int j = 1 ; j <= i ; j++){
cin >> dp[i][j];
}
}
for(int i=1 ; i <= n ; i++){
for(int j=1 ; j <= i ; j++){
if(j == 1){
dp[i][j] += dp[i-1][j];
}
else if(i == j){
dp[i][j] += dp[i-1][j-1];
}
else{
dp[i][j] += max(dp[i-1][j-1],dp[i-1][j]);
}
}
}
ll ans = dp[n][1];
for(int i=2 ; i <= n ; i++){
ans = max(ans,dp[n][i]);
}
cout << ans;
return 0;
}