携程0905笔试第二题

看解答都是三维dp
好像二维dp也能做
dp[i][j]表示子串s[i...j]全变为1的最小操作数
public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        String s = in.next();
        char[] cs = s.toCharArray();

        int res = 0;

        int[][] dp = new int[n][n];
        for(int i = 0; i < n; i++){
            dp[i][i] = cs[i] == '0' ? 1 : 0;
            res += cs[i] == '0' ? 1 : 0;
        }

        for (int i = n - 1; i >= 0; i--) {
            for(int j = i + 1; j < n; j++){
                if(cs[j] == '1'){
                    dp[i][j] = dp[i][j - 1];
                }else{
                    if(cs[j - 1] == '0'){
                        dp[i][j] = dp[i][j - 1];
                    }else{
                        dp[i][j] = dp[i][j - 1] + 2;
                    }
                }

                if((j - i + 1) % 2 != 0 &amp;&amp; dp[i][j] % 2 != 0){
                    res ++;
                }
            }
        }
        System.out.println(res);
    }
全部评论

相关推荐

面了这么多场试,总有公司总喜欢压力面一个小时面试+手撕,哪里不会就点哪里,说了不会不会还继续追着问不尊重求职者,稍微有些细节记不清了,就开始怀疑项目真实性以及人格让求职者开摄像头但是自己不开,说话声音还贼小,pardon几次就开始不耐烦的不知道这个算不算,手撕的时候,面试官人跑了。。。最后快结束才来
一纸丿繁华丶:你换位思考一下,自己在职场被领导push麻了,身心俱疲,现在有个机会让你放松一下,体验一把上位者的感觉,还能看着那些高学历人才、未来自己的竞争者,抓耳挠腮、手足无措的样子,没给你当场笑出来就不错了,理解一下面试官吧。
点赞 评论 收藏
分享
05-16 11:16
已编辑
东华理工大学 Java
牛客737698141号:盲猜几十人小公司,庙小妖风大,咋不叫她去4️⃣呢😁
点赞 评论 收藏
分享
真烦好烦真烦:牛友太有实力了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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