翻转后1的数量(dp)

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        String s = sc.next();
        
        int cnt1 = 0;  // 原本1的个数
        int[] gain = new int[n + 1];
        
        // 构造gain数组
        for (int i = 1; i <= n; i++) {
            if (s.charAt(i - 1) == '1') {
                cnt1++;
                gain[i] = -1;  // 翻转会减少一个1
            } else {
                gain[i] = 1;   // 翻转会增加一个1
            }
        }
        
        // DP数组
        int[] dp = new int[n + 1];
        dp[1] = gain[1];
        int maxGain = dp[1];
        
        // 动态规划求最大子段和
        for (int i = 2; i <= n; i++) {
            dp[i] = Math.max(gain[i], dp[i - 1] + gain[i]);
            maxGain = Math.max(maxGain, dp[i]);
        }
        
        System.out.println(cnt1 + maxGain);
    }
}

最大子段和问题

相关推荐
L0CK6 分钟前
三种依赖注入详解
java
业精于勤的牙11 分钟前
三角形最小路径和(二)
算法
风筝在晴天搁浅13 分钟前
hot100 239.滑动窗口最大值
数据结构·算法·leetcode
夏乌_Wx25 分钟前
练题100天——DAY31:相对名次+数组拆分+重塑矩阵
数据结构·算法
LYFlied25 分钟前
【算法解题模板】-解二叉树相关算法题的技巧
前端·数据结构·算法·leetcode
shoubepatien28 分钟前
JAVA -- 07
java·后端·intellij-idea
Gu_yyqx30 分钟前
Maven进阶
java·maven
小肖爱笑不爱笑32 分钟前
JavaScript
java·javascript·json·web
专注于大数据技术栈32 分钟前
java学习--String和StringBuffer互转
java·学习
Ven%1 小时前
【AI大模型算法工程师面试题解析与技术思考】
人工智能·python·算法