2024.3.31 腾讯笔试第四题

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    int n = in.nextInt();
    int k = in.nextInt();
    long[][] dp = new long[k + 1][n + 1];

    for (int i = 0; i < n; i++) {
        dp[1][i + 1] = in.nextInt() ^ dp[1][i];
    }

    long[] prefix = dp[1];
    // 拆分为 i 份
    for (int i = 2; i <= k; i++) {
        // 从头到尾遍历:将第 1~j 个元素拆成 i 份
        for (int j = i; j <= n; j++) {
            long max = 0;
            // 将第 [1,s] 个元素拆成 i-1 份,(s,j] 是最后一份
            for (int s = j - 1; s >= i - 1; s--) {
                // 异或的优先级小于加减法
                max = Math.max(max, dp[i - 1][s] + (prefix[j] ^ prefix[s]));
            }
            dp[i][j] = max;
        }
    }

    System.out.println(dp[k][n]);
}

全部评论
大佬😍
点赞 回复 分享
发布于 2024-04-03 17:31 广东

相关推荐

把实习生当正职使昨天第一天就加班,晚上连口饭都没吃上,以后日子咋过,我不想干了
码农索隆:实习不怕忙,就怕干的活重复且没难度,要干就干那种有深度有难度的任务,这样才能快速的提升
实习吐槽大会
点赞 评论 收藏
分享
06-27 18:45
中山大学 Ruby
25届应届毕业生,来广州2个礼拜了,找不到工作,绝望了,太难过了…
应届想染班味:9爷找不到工作只能说明,太摆了或者太挑了。
点赞 评论 收藏
分享
qq乃乃好喝到咩噗茶:院校后面加上211标签,放大加粗,招呼语也写上211
点赞 评论 收藏
分享
06-26 17:24
已编辑
宁波大学 Java
一口洪烧肉:哈哈哈哈哈哈哈哈哈哈哈硬要啊
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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