#include <iostream>
#include <vector>
using namespace std;
int rob_linear(vector<int>& nums);
int main() {
    int n;
    cin>>n;
    vector<int> arr(n,0);
    for(int i=0;i<n;i++){
        cin>>arr[i];
    }
    if(n==0) return 0;
    vector<int> temp1=vector<int>(arr.begin(),arr.end()-1);
    vector<int> temp2=vector<int>(arr.begin()+1,arr.end());
    int res1=rob_linear(temp1);
    int res2=rob_linear(temp2);
    cout<<(res1>res2?res1:res2);
    return 0;
    // int res=max(,)
}
int rob_linear(vector<int>& nums){
    int n=nums.size();
    vector<int> dp(n+1,0);
    if(n==0) return 0;
    if(n==1) return nums[0];
    else{
        dp[0]=0;
        dp[1]=nums[0];
        for(int i=2;i<n+1;i++){
            dp[i]=max(dp[i-1],dp[i-2]+nums[i-1]);
        }
    }
    return dp[n];
}
// 64 位输出请用 printf("%lld")