2021-03-12

leetcode 474. 一和零

题目描述:

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

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

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

这个题目有点类似于0-1背包问题,但是它比0-1背包问题更加复杂,因为它有m和n两个限制条件。

因此我们可以创建一个二维数组vec,vec[i][j]表示在限制条件为最多有i个0和j个1时,可以存放的最多的字符串数。数组的第一行和第一列均为0。

class Solution {
public:
    int findMaxForm(vector<string>& strs, int m, int n) {
        vector<vector<int> > vec(m + 1, vector<int> (n + 1, 0));
        for(string s:strs)
        {
            int oneNum = 0, zeroNum = 0;
            for(char c : s)
            {
                if(c == '1')
                {
                    oneNum ++;
                }
                else
                    zeroNum++;
            }
            for(int i=m;i>=0;i--)
            {
                for(int j=n;j>=0;j--)
                {
                    if(i>=zeroNum&&j>=oneNum)
                        vec[i][j] = max(vec[i-zeroNum][j-oneNum]+1,vec[i][j]);
                }
            }
        }
        return vec[m][n];
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
embedcpp-2021-03是一个有关嵌入式C++编程的课程,于2021年3月举办。嵌入式C++编程是指在嵌入式系统中使用C++编程语言进行开发的一种方法。 在嵌入式系统中,资源通常是有限的,例如处理器速度、内存容量和存储空间等。因此,使用C++编程语言可以提供更高的灵活性和效率,帮助开发人员充分利用有限的资源。C++在嵌入式系统中的应用范围广泛,例如物联网设备、汽车电子和工业自动化等领域。 embedcpp-2021-03课程旨在向学员介绍嵌入式C++编程的基础知识和技巧。课程内容通常包括以下方面: 1. C++语法和特性:介绍C++的基本语法、面向对象编程和泛型编程等概念,以及C++11、C++14和C++17的一些新特性。 2. 嵌入式系统概述:了解嵌入式系统的基本特点、硬件和软件组成,以及与传统桌面开发的区别。 3. 低级编程:学习如何与硬件交互,包括使用寄存器、配置外设和处理中断等。还可以介绍使用汇编语言优化性能的技巧。 4. 内存管理:探讨嵌入式系统中的内存管理技术,包括堆栈和堆的使用、动态内存分配和对象生命周期管理等。 5. 实时操作系统(RTOS):介绍嵌入式系统中常用的实时操作系统,如FreeRTOS和µC/OS等,学习如何使用RTOS进行任务调度和资源管理。 除了理论知识,embedcpp-2021-03课程通常还包括实际的项目练习,以帮助学员将所学知识应用于实际场景。通过该课程,学员可以了解嵌入式C++编程的基础概念和实践技巧,为嵌入式系统开发提供了一定的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值