打家劫舍
注解
f[i]: 第i个元素必选时,能够得到的最大价值。
g[i]: 第i个元素必不选时,能够得到的最大价值。
class Solution {
public int rob(int[] nums) {
int n = nums.length;
int[] f = new int[n + 1];
int[] g = new int[n + 1];
for (int i = 1; i <= n; i ++) {
f[i] = g[i - 1] + nums[i - 1];
g[i] = Math.max(f[i - 1], g[i - 1]);
}
return Math.max(f[n], g[n]);
}
}