Java 求解一和零

Posted 南淮北安

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java 求解一和零相关的知识,希望对你有一定的参考价值。

一、题目

给你一个二进制字符串数组 strs 和两个整数 m 和 n 。

请你找出并返回 strs 的最大子集的大小,该子集中 最多 有 m 个 0 和 n 个 1 。

如果 x 的所有元素也是 y 的元素,集合 x 是集合 y 的 子集 。

二、背包解析

该题仍然可以按照背包问题去解析

字符串数组里的元素,可以看作物品

m和n相当于背包,两个维度的背包

(1)确定 dp 数组

dp[i][j] 表示 i 个零和 j 个一时最大子集数目

(2)确定递推表达式

dp[i][j]=Math.max(dp[i][j],dp[i-zeroNum][j-oneNum]+1)
表示字符串要么放,要么不放

(3)确定初始化

物品不会是负数,所以初始为0

(4)确定遍历顺序

这里虽然是二维数组,但是仍然是类似前面的一维数组,每次都覆盖上一行,所以从后往前遍历

三、代码

class Solution 
    public int findMaxForm(String[] strs, int m, int n) 
        //dp[i][j]表示i个0和j个1时的最大子集
        int[][] dp = new int[m + 1][n + 1];
        int oneNum, zeroNum;
        for (String str : strs) 
            oneNum = 0;
            zeroNum = 0;
            for (char ch : str.toCharArray()) 
                if (ch == '0') 
                    zeroNum++;
                 else 
                    oneNum++;
                
            
            //倒序遍历
            for (int i = m; i >= zeroNum; i--) 
                for (int j = n; j >= oneNum; j--) 
                    dp[i][j] = Math.max(dp[i][j], dp[i - zeroNum][j - oneNum] + 1);
                
            
        
        return dp[m][n];
    

四、总结

该题重在转为背包问题去考虑

而且容量是两个维度

以上是关于Java 求解一和零的主要内容,如果未能解决你的问题,请参考以下文章

leetcode 474. 一和零(01背包问题)

[474]. 一和零

[474]. 一和零

《LeetCode之每日一题》:53.一和零

Leetcode 474.一和零

leetcode 474. 一和零