类似打家劫舍一: 就是dp[i]表示以i-1结尾的数组的最大值: import java.util.*; public class Main{

public static int process(int[] arr,int n){
    int[]dp=new int[n+1];
    dp[1]=arr[0];
    int res=dp[1];
    for(int i=2;i<=n;i++){
        dp[i]=Math.max(dp[i-2]+arr[i-1],dp[i-1]);
        res=Math.max(res,dp[i]);
    }
    return res;
}


public static void main(String[]args){
    Scanner sc=new Scanner(System.in);
    int n=sc.nextInt();
    int[]arr=new int[n];
    for(int i=0;i<n;i++)
        arr[i]=sc.nextInt();
    System.out.print(process(arr,n));
}

}