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< ...
随机推荐
- Centos8 安装 Redis6.0.16
下载,解压,编译,安装 安装至 /opt/redis/redis-6.0.16 目录 tar xvf redis-6.0.16.tar.gz gcc --version cd redis-6.0.16 ...
- 解决unable to find valid certification path to requested target
问题描述 最近java程序去调用远程服务器接口时报错了: I/O error on POST request for "https://XXX.xyz/create": sun.s ...
- [攻防世界][江苏工匠杯]file_include
打开靶机url,上来就是代码审计 <?php highlight_file(__FILE__); include("./check.php"); if(isset($_GET ...
- 【LeetCode链表#8】翻转链表(双指针+递归)/K个一组翻转
翻转链表 力扣题目链接(opens new window) 题意:反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4-> ...
- sql组合索引怎样使用?怎样命中?
一.联合索引的使用 本文中联合索引的定义为(MySQL): ALTER TABLE table_name ADD INDEX (col1,col2,col3); 二.联合索引的本质 当创建(col1, ...
- maven配置全局私服地址和阿里云仓库
直接上配置代码 <?xml version="1.0" encoding="UTF-8"?> <!-- Licensed to the Apa ...
- 【Azure Logic App】在Logic App中使用 Transfer XML组件遇见错误 undefined
问题描述 在Azure Logic App中,使用Transform XML组件进行XML内容的转换,但是最近这个组件运行始终失败. 问题解答 点击Transform XML组件上的错误案例,并不能查 ...
- 【应用服务 App Service】App Service 中部署Java项目,查看Tomcat配置及上传自定义版本
当在Azure 中部署Java应用时候,通常会遇见下列的问题: 如何部署一个Java的项目呢? 部署成功后,怎么来查看Tomcat的服务器信息呢? 如果Azure提供的默认Tomcat版本的配置跟应用 ...
- 【Azure 存储服务】App Service 访问开启防火墙的存储账号时遇见 403 (This request is not authorized to perform this operation.)
问题描述 需要 App Service 访问开启防火墙的存储账号.存储账号中设置为允许选中的VNET访问,同时允许了信任的Azure服务的访问,但是仍然报错 "403 (This reque ...
- 360 数科实践:JanusGraph 到 NebulaGraph 迁移
摘要:在本文中 360 数科的周鹏详细讲解了业务从 JanusGraph 迁移到 Nebula Graph 带来的性能提升,在机器资源不到之前 JanusGraph 配置三分之一的情况下,业务性能提升 ...