#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param nums int整型一维数组 
# @return int整型
#
class Solution:
    def rob(self , nums: List[int]) -> int:
        # write code here
        # 只有一个时候
        n =len(nums)
        if n==1:
            return nums[0] # 只能选择第一个
        if n ==2: # 情况2;只能选择其中一种
            return max(nums[0],nums[1])
        # 超过两个元素分为两段 [0,n-2]  [1,n-1]
        # [0,n-2]
        dp1=[0]*(n)
        dp1[0]=nums[0]
        dp1[1]=nums[1]
        for i in range(2,n-1):
            dp1[i]=max(dp1[i-1],dp1[i-2]+nums[i])
        # [1,n-1]
        dp2=[0]*(n)
        dp2[1]=nums[1]
        dp2[2]=nums[2]
        for i in range(3,n):
            dp2[i]=max(dp2[i-1],dp2[i-2]+nums[i])
        print(dp1)
        print(dp2)
        return max(dp1[n-2],dp2[n-1])