2024-03-27:用go语言,多维费用背包。 给你一个二进制字符串数组 strs 和两个整数 m 和 n, 请你找出并返回 strs 的最大子集的长度,该子集中 最多 有 m 个 0 和 n 个
2024-03-27:用go语言,多维费用背包。
给你一个二进制字符串数组 strs 和两个整数 m 和 n,
请你找出并返回 strs 的最大子集的长度,该子集中 最多 有 m 个 0 和 n 个 1。
如果 x 的所有元素也是 y 的元素,集合 x 是集合 y 的 子集。
输入:strs = ["10", "0001", "111001", "1", "0"], m = 5, n = 3。
输出:4。
答案2024-03-27:
来自左程云。
大体步骤如下:
1.findMaxForm1 函数使用递归的方式实现。它遍历字符串数组 strs,将每个字符串中0和1的数量存储在一个二维数组 arr 中。然后通过递归函数 process1 进行计算,不断比较所选字符串是否符合要求,选择放入或不放入子集。该方法的时间复杂度为O(2^n),空间复杂度为O(n)。
2.findMaxForm2 函数使用记忆化搜索的方式实现。它也遍历字符串数组 strs 得到二维数组 arr,但使用三维数组 dp 进行记忆化,记录已经计算过的结果,避免重复计算。该方法的时间复杂度为O(m * n * len(strs)),空间复杂度为O(m * n * len(strs))。
3.findMaxForm3 函数使用动态规划的方式实现。它从后向前遍历字符串数组 strs,得到二维数组 dp 来保存计算结果。通过比较选择当前字符串加入子集还是不加入子集,并更新动态规划数组 dp。该方法的时间复杂度为O(m * n * len(strs)),空间复杂度为O(m * n * len(strs))。
4 findMaxForm4 函数使用动态规划的方式实现。它遍历字符串数组 strs,得到二维数组 dp 来保存计算结果。使用一维数组 dp 进行滚动更新,从后向前遍历,根据当前字符串的0和1的数量,更新动态规划数组 dp。该方法的时间复杂度为O(m * n * len(strs)),空间复杂度为O(m * n)。
总时间复杂度:O(m * n * len(strs))
总额外空间复杂度:O(m * n * len(strs))
Go完整代码如下:
package main
import (
"fmt"
)
var zeros, ones int
func findMaxForm1(strs []string, m int, n int) int {
len := len(strs)
arr := make([][]int, len)
for i := 0; i < len; i++ {
zeroAndOne(strs[i])
arr[i] = []int{zeros, ones}
}
return process1(arr, 0, m, n)
}
func process1(arr [][]int, i int, z int, o int) int {
if i == len(arr) {
return 0
}
p1 := process1(arr, i+1, z, o)
p2 := 0
if arr[i][0] <= z && arr[i][1] <= o {
p2 = 1 + process1(arr, i+1, z-arr[i][0], o-arr[i][1])
}
if p1 > p2 {
return p1
}
return p2
}
func findMaxForm2(strs []string, m int, n int) int {
len := len(strs)
arr := make([][]int, len)
for i := 0; i < len; i++ {
zeroAndOne(strs[i])
arr[i] = []int{zeros, ones}
}
dp := make([][][]int, len)
for i := 0; i < len; i++ {
dp[i] = make([][]int, m+1)
for j := 0; j <= m; j++ {
dp[i][j] = make([]int, n+1)
for k := 0; k <= n; k++ {
dp[i][j][k] = -1
}
}
}
return process2(arr, 0, m, n, dp)
}
func process2(arr [][]int, i int, z int, o int, dp [][][]int) int {
if i == len(arr) {
return 0
}
if dp[i][z][o] != -1 {
return dp[i][z][o]
}
p1 := process2(arr, i+1, z, o, dp)
p2 := 0
if arr[i][0] <= z && arr[i][1] <= o {
p2 = 1 + process2(arr, i+1, z-arr[i][0], o-arr[i][1], dp)
}
ans := p1
if p2 > p1 {
ans = p2
}
dp[i][z][o] = ans
return ans
}
func findMaxForm3(strs []string, m int, n int) int {
len0 := len(strs)
dp := make([][][]int, len0+1)
for i := len0; i >= 0; i-- {
dp[i] = make([][]int, m+1)
for z := 0; z <= m; z++ {
dp[i][z] = make([]int, n+1)
}
}
for i := len0 - 1; i >= 0; i-- {
zeroAndOne(strs[i])
for z := 0; z <= m; z++ {
for o := 0; o <= n; o++ {
dp[i][z][o] = dp[i+1][z][o]
if zeros <= z && ones <= o {
dp[i][z][o] = max(dp[i][z][o], 1+dp[i+1][z-zeros][o-ones])
}
}
}
}
return dp[0][m][n]
}
func zeroAndOne(str string) {
zeros = 0
ones = 0
for i := 0; i < len(str); i++ {
if str[i] == '0' {
zeros++
} else {
ones++
}
}
}
func findMaxForm4(strs []string, m int, n int) int {
dp := make([][]int, m+1)
for i := 0; i <= m; i++ {
dp[i] = make([]int, n+1)
}
for _, s := range strs {
zeroAndOne(s)
for i := m; i >= zeros; i-- {
for j := n; j >= ones; j-- {
dp[i][j] = max(dp[i][j], dp[i-zeros][j-ones]+1)
}
}
}
return dp[m][n]
}
func max(a, b int) int {
if a > b {
return a
}
return b
}
func main() {
strs := []string{"10", "0001", "111001", "1", "0"}
m := 5
n := 3
res1 := findMaxForm1(strs, m, n)
fmt.Println("findMaxForm1:", res1)
res2 := findMaxForm2(strs, m, n)
fmt.Println("findMaxForm2:", res2)
res3 := findMaxForm3(strs, m, n)
fmt.Println("findMaxForm3:", res3)
res4 := findMaxForm4(strs, m, n)
fmt.Println("findMaxForm4:", res4)
}

Python完整代码如下:
# -*-coding:utf-8-*-
def zero_and_one(string):
zeros = 0
ones = 0
for char in string:
if char == '0':
zeros += 1
else:
ones += 1
return zeros, ones
def find_max_form1(strs, m, n):
length = len(strs)
arr = []
for i in range(length):
zeros, ones = zero_and_one(strs[i])
arr.append((zeros, ones))
return process1(arr, 0, m, n)
def process1(arr, i, z, o):
if i == len(arr):
return 0
p1 = process1(arr, i+1, z, o)
p2 = 0
if arr[i][0] <= z and arr[i][1] <= o:
p2 = 1 + process1(arr, i+1, z-arr[i][0], o-arr[i][1])
if p1 > p2:
return p1
return p2
def find_max_form2(strs, m, n):
length = len(strs)
arr = []
for i in range(length):
zeros, ones = zero_and_one(strs[i])
arr.append((zeros, ones))
dp = [[[-1] * (n+1) for _ in range(m+1)] for _ in range(length)]
return process2(arr, 0, m, n, dp)
def process2(arr, i, z, o, dp):
if i == len(arr):
return 0
if dp[i][z][o] != -1:
return dp[i][z][o]
p1 = process2(arr, i+1, z, o, dp)
p2 = 0
if arr[i][0] <= z and arr[i][1] <= o:
p2 = 1 + process2(arr, i+1, z-arr[i][0], o-arr[i][1], dp)
ans = p1
if p2 > p1:
ans = p2
dp[i][z][o] = ans
return ans
def find_max_form3(strs, m, n):
length = len(strs)
dp = [[[0] * (n+1) for _ in range(m+1)] for _ in range(length+1)]
for i in range(length-1, -1, -1):
zeros, ones = zero_and_one(strs[i])
for z in range(m+1):
for o in range(n+1):
dp[i][z][o] = dp[i+1][z][o]
if zeros <= z and ones <= o:
dp[i][z][o] = max(dp[i][z][o], 1 + dp[i+1][z-zeros][o-ones])
return dp[0][m][n]
def find_max_form4(strs, m, n):
dp = [[0] * (n+1) for _ in range(m+1)]
for s in strs:
zeros, ones = zero_and_one(s)
for i in range(m, zeros-1, -1):
for j in range(n, ones-1, -1):
dp[i][j] = max(dp[i][j], dp[i-zeros][j-ones]+1)
return dp[m][n]
strs = ["10", "0001", "111001", "1", "0"]
m = 5
n = 3
res1 = find_max_form1(strs, m, n)
print("findMaxForm1:", res1)
res2 = find_max_form2(strs, m, n)
print("findMaxForm2:", res2)
res3 = find_max_form3(strs, m, n)
print("findMaxForm3:", res3)
res4 = find_max_form4(strs, m, n)
print("findMaxForm4:", res4)

2024-03-27:用go语言,多维费用背包。 给你一个二进制字符串数组 strs 和两个整数 m 和 n, 请你找出并返回 strs 的最大子集的长度,该子集中 最多 有 m 个 0 和 n 个的更多相关文章
- 给定两个list A ,B,请用找出 A ,B中相同的元素,A ,B中不同的元素 ??
A.B 中相同元素:print(set(A)&set(B)) A.B 中不同元素:print(set(A)^set(B))
- 【leetcode-03】给定一个字符串,请你找出其中不含有重复字符的最长子串的长度
开个新坑,leetcode上面做题目.下面是题目描述: <!-- 给定一个字符串,请你找出其中不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出 ...
- 给定一个set字符和一个正数k,找出所有该做set它可以由长度构成k该字符串集合 print-all-combinations-of-given-length
// 给定一个set字符和一个正数k,找出所有该做set它可以由长度构成k该字符串集合 /* Input: set[] = {'a', 'b'}, k = 3 Output: aaa aab aba ...
- hdu2159二维费用背包
题目连接 背包九讲----二维费用背包 问题 二维费用的背包问题是指:对于每件物品,具有两种不同的费用:选择这件物品必须同时付出这两种代价:对于每种代价都有一个可付出的最大值(背包容量).问怎样选择物 ...
- 洛谷 P1507 NASA的食物计划 【二维费用背包】 || 【DFS】
题目链接:https://www.luogu.org/problemnew/show/P1507 题目背景 NASA(美国航空航天局)因为航天飞机的隔热瓦等其他安全技术问题一直大伤脑筋,因此在各方压力 ...
- Regionals 2014 >> Asia - Taichung 7003 - A Balance Game on Trees 树形DP + 二维费用背包
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 洛谷 P1509 找啊找啊找GF(复习二维费用背包)
传送门 题目背景 "找啊找啊找GF,找到一个好GF,吃顿饭啊拉拉手,你是我的好GF.再见." "诶,别再见啊..." 七夕...七夕...七夕这个日子,对于sq ...
- codevs1959拔河比赛(二维费用背包)
1959 拔河比赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 一个学校举行拔河比赛,所有的人被分成了两组,每个人 ...
- 榨取kkksc03 luogu1855 dp 裸二维费用背包
首先对于这个题目背景,,个人认为很(you)好(qu),,, 核心就是一个裸的二维费用背包,刚刚学习的同学参见dd大牛的背包九讲 #include <cstdio> #include &l ...
- hdu_2159(二维费用背包)
HDU_2159 二维费用背包问题 http://acm.hdu.edu.cn/showproblem.php?pid=2159 #include<cstdio> #include< ...
随机推荐
- springboot集成腾讯cos实现文件上传
腾讯对象存储介绍 对象存储(Cloud Object Storage,COS)是腾讯云提供的一种存储海量文件的分布式存储服务,具有高扩展性.低成本.可靠安全等优点.通过控制台.API.SDK 和工具等 ...
- Java设计模式-适配器模式Adapter
介绍 适配器模式(Adapter Pattern)将某个类的接口转换成客户端期望的另一个接口表示,主的目的是兼容性,让原本 因接口不匹配不能一起工作的两个类可以协同工作.其别名为包装器(Wrapper ...
- ORA-39087: Directory Name Is Invalid
说明 有时我们在Oracle数据库服务器执行expdp/impdp过程中会碰到这个错误:ORA-39087: Directory Name Is Invalid,意思是我们指定的directory参数 ...
- maven打包时打包指定的lib文件夹
今天在打包自己的spring boot项目时遇到了问题, 报找不到类和符号. 因为我有些依赖是放在项目lib文件夹中,那么打包的时候要连把它一起打包. 修改pom.xml, 添加一下内容: <b ...
- Fpga开发笔记(二):高云FPGA发开发软件Gowin和高云fpga基本开发过程
前言 本篇安装高云的开发软件Gowin,并且描述了一个基于高云fpga的程序的开发环境和完整的下载运行过程. Gowin软件 概述 Gowin 软件是广东高云半导体股份有限公司的 FPGA ...
- Linux开端---Centos
Linux-Centos 虚拟化所需工具:https://pan.baidu.com/s/1643-kYcx9oPGnGEZM1pLOw?pwd=g0v5 提取码:g0v5 问题解决 正常注册网络适配 ...
- 【LeetCode哈希表】前k个高频词,利用哈希表+vector进行排序操作
前k个高频词 https://leetcode.cn/problems/top-k-frequent-words/ 给定一个单词列表 words 和一个整数 k ,返回前 k 个出现次数最多的单词. ...
- 《HelloGitHub》第 95 期
兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...
- 【Azure Function App】Java Function部署到Azure后出现中文显示乱码问题
问题描述 Java Function在Azure上遇见中文显示乱码问题?如何解决呢? 问题解答 中文字符显示为乱码,这个情况就是服务实例上设置的编码格式不是统一的UTF-8所导致的. 在查看Azure ...
- 【Azure Redis 缓存】Azure Redis加入VNET后,在另一个区域(如中国东部二区)的VNET无法访问Redis服务(注:两个VNET已经结对,相互之间可以互ping)
问题描述 为了保护Redis资源,把它与VNET集成后,实现只能通过VNET内网访问.在东二的区域中部署两个Redis服务后,发现一个奇怪的现象:东1区中的VM资源通过全局对等互联(Peering)实 ...