#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")