Java dp不压缩

不相邻最大子序列和

http://www.nowcoder.com/questionTerminal/269b4dbd74e540aabd3aa9438208ed8d

每个位置有两个状态, 拿或者不拿

  • 拿当前位置时, 最大值只能从 不拿上一个位置 转移来
  • 不拿当前位置时,最大值可以从 不拿上一个位置拿上一个位置 转移

写出dp:

    public long subsequence (int n, int[] array) {

        long[][] dp = new long[2][n+5];
        dp[0][0]=array[0];
        dp[1][0]=0;
        dp[0][1]=array[1];
        dp[1][1]=dp[0][0];
        for(int i=2;i<array.length;++i){
            dp[0][i] = dp[1][i-1]+array[i];
            dp[1][i]=Math.max(dp[1][i-1],dp[0][i-1]);
        }
        return Math.max(dp[1][n-1],dp[0][n-1]);
    }

观察到每次转移只依赖上一个位置, 所以可以做状态压缩

全部评论

相关推荐

12-06 16:17
济宁学院 Java
点赞 评论 收藏
分享
友友们,我实在是不太明白,校招的话现在大多也是提前实习,然后转正也是需要考核的,考核通过才能转正,那这跟实习转正有什么区别啊
苦闷的仰泳鲈鱼刷了1...:提前实习,是让你提前熟悉业务的,后续是入职后可以减少试用期的(大部分是包入职的);转正实习,要是hc不够或者其他原因,让你正式offer可能都没有,这个风险很大。 ---个人看法和了解到的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务