dp专题11 一和零

本题链接:. - 力扣(LeetCode)

题目:dp专题11 一和零_第1张图片dp专题11 一和零_第2张图片

思路:

        由题意,这里有两个特征,要求满足选取的字符串总和中,0的个数和1的个数分别不超过m个0 和 n个 1,问选取的字符串最多有多少个。

        又是典型的背包问题,这里我们选取的个数变成了两个,所以这是个二维dp

其中我们明确一下 dp[ i ][ j ] 的含义是我们选取的字符串数量,即价值为 1 ,将 n 和 m 作为背包容量即可。

代码详解如下:

class Solution {
public:
    inline int findMaxForm(vector& strs, int m, int n) 
{
	vector>dp(101,vector(101,0));	// 根据题目范围开辟极限大小
	
	for(string &i:strs)		// 遍历我们是否要选取的字符串,  
	{
		int one = 0,zero = 0;	// 统计该字符串的 0  和  1  的数量
		for(char &j:i) 
			if(j - '0') ++one;
			else ++zero;
		
		// 遍历 容量
		for(int j = m;j >= zero;--j)
		{
			for(int k = n;k >= one;--k)
			{
				dp[j][k] = max(dp[j][k],dp[j - zero][k - one] + 1);		// 推导判断是否选取
			}
		}
	}
	return dp[m][n];	// 返回选取字符串最多的数量
}
};

最后提交:dp专题11 一和零_第3张图片

你可能感兴趣的:(算法笔记,算法)