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 广东

相关推荐

不愿透露姓名的神秘牛友
昨天 17:30
点赞 评论 收藏
分享
陆续:不可思议 竟然没那就话 那就我来吧 :你是我在牛客见到的最美的女孩
点赞 评论 收藏
分享
后来123321:别着急,我学院本大二,投了1100份,两个面试,其中一个还是我去线下招聘会投的简历,有时候这东西也得看运气
无实习如何秋招上岸
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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