leetcode 474 一和零

一、题目描述

二、解题思路

解法一:深度优先搜索+剪枝(超时)

本题实际上与0/1背包问题类似,即子集问题的变种,可以采用深度优先搜索+剪枝来解决这个问题,对于每一个字符串,只有选择和不选择两种决策。

解法二:动态规划

dpij表示m=i,n=j时,最大的子集数,对于每一个字符串,只有选择与不选择两种情况,所以dpij=max(dpij,dpi-zerosj-ones),这就是状态转移方程,依此来写就可以了。

三、代码实现

解法一:深度优先搜索+剪枝(超时)

cpp 复制代码
class Solution {
    int length;
    vector<vector<int>> count;
public:
    int findMaxForm(vector<string>& strs, int m, int n) {
        //初始化全局变量
        length=0;
        
        //初始化count数组,记录每个字符串中'0'和'1'的个数
        count.resize(strs.size(),vector<int>(2,0));
        for(int i=0;i!=strs.size();i++){
            for(auto ch:strs[i]){
                if(ch=='0') count[i][0]++;
                else if(ch=='1') count[i][1]++;
            }
        }

        dfs(strs,0,m,n,0);
        return length;
    }
    void dfs(vector<string>& strs,int start,int m,int n,int currentLength){
        //递归出口
        if(start==strs.size()){
            length=max(length,currentLength);
            return ;
        }

        //当前字符串的'1'和'0'的数量
        int zeros=count[start][0];
        int ones=count[start][1];

        //选
        if(m>=zeros&&n>=ones)
            dfs(strs,start+1,m-zeros,n-ones,currentLength+1);
        //不选
        dfs(strs,start+1,m,n,currentLength);
    }
};

解法二:动态规划(可通过)

cpp 复制代码
class Solution {
public:
    int findMaxForm(vector<string>& strs, int m, int n) {
        //动态规划
        //dp[i][j]表示m=i,n=j时,最大子集的长度
        vector<vector<int>> dp(m+1,vector<int>(n+1,0));
        for(auto str:strs){
            int zeros=count(str.begin(),str.end(),'0');
            int ones=(int)str.size()-zeros;
            //填写dp数组
            for(int i=m;i>=zeros;i--)
                for(int j=n;j>=ones;j--)
                    dp[i][j]=max(dp[i][j],dp[i-zeros][j-ones]+1);
        }
        return dp[m][n];
    }
};
相关推荐
8Qi81 天前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
好评1241 天前
【C++】智能指针全解
c++·智能指针
bIo7lyA8v1 天前
算法稳定性分析中的随机扰动建模的技术8
算法
是阿建吖!1 天前
【Linux】信号
android·linux·c语言·c++
城北徐宫1 天前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
liulilittle1 天前
论 Linux 内核态全局稳态带宽的卡尔曼估计与工程实现
linux·服务器·网络·c++·计算机网络·tcp·通信
XBodhi.1 天前
Visual Studio C++ 语法错误: 缺少“;”(在“return”的前面)
开发语言·c++·visual studio
科研online1 天前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy1 天前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯1 天前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法