【代码随想录训练营】【Day 44】【动态规划-4】| 卡码 46, Leetcode 416

【代码随想录训练营】【Day 44】【动态规划-4】| 卡码 46, Leetcode 416

需强化知识点

  • 背包理论知识

题目

卡码 46. 携带研究材料

  • 01 背包理论基础
  • 01 背包理论基础(滚动数组)
  • 01 背包 二维版本:dp[i][j] 表示从下标为[0-i]的物品里任意取,放进容量为j的背包,价值总和最大是多少,注意 遍历和初始化时 n 要取到
  • 01 背包 一维版本:dp[j]为 容量为j的背包所背的最大价值,注意 先遍历 物品,再重量(倒序遍历)
python 复制代码
def func(m, n, weight, value):
    # dp[i][j] 表示从下标为[0-i]的物品里任意取,放进容量为j的背包,价值总和最大是多少。
    # 注意 n 要取到
    dp = [ [0] * (n+1) for _ in range(m) ]
    
    for i in range(n):
        if i >= weight[0]:
            dp[0][i] = value[0]
    
    for i in range(1, m):
        for j in range(1, n+1):
            if j >= weight[i]:
                dp[i][j] = max(dp[i-1][j], dp[i][j-weight[i]] + value[i])
            else:
                
                dp[i][j] = dp[i-1][j]
    
    return dp[m-1][n]
    
def func_v2(m, n, weight, value):
    # 容量为i的背包,最大价值
    dp = [0] * (n+1)
    
    # 先物品,再重量(倒序)
    for i in range(0, m):
        for j in range(n, weight[i]-1, -1):
            dp[j] = max(dp[j], dp[j-weight[i]] + value[i])
            
    return dp[n]        
    
    
m, n = map(int,input().split())
weight = list(map(int,input().split()))
value = list(map(int,input().split()))

print(func_v2(m, n, weight, value))

416. 分割等和子集

  • 动态规划:01背包问题,重量为 target,价值为数值
  • 使用 回溯+剪枝的方法会超时,注意对于返回 布尔值的处理
python 复制代码
class Solution:
    def canPartition(self, nums: List[int]) -> bool:
        if sum(nums) % 2:
            return False

        target = sum(nums) // 2
        dp = [0] * (target+1)

        for i in range(len(nums)):
            for j in range(target, nums[i]-1, -1):
                dp[j] = max(dp[j], dp[j - nums[i]] + nums[i])
                if dp[j] == target:
                    return True
        return False




        # 回溯 + 剪枝 超时,注意bool 类型返回值的方式(目前只能想到这种)
        # def backtracking(path, result, startIndex, target, nums):
        #     if startIndex >= len(nums) or sum(path) > target:
        #         return
        #     if sum(path) == target:
        #         result[0] = True
        #         return
            
        #     for i in range(startIndex, len(nums)):
        #         if sum(path) + nums[i] > target:
        #             break
        #         path.append(nums[i])
        #         backtracking(path, result, i+1, target, nums)
        #         path.pop()
        
        # result = [False]
        # if sum(nums) % 2:
        #     return False
        # else:
        #     nums.sort()
        #     backtracking([], result, 0, sum(nums) // 2, nums)
        #     return result[0]
相关推荐
未来之窗软件服务4 小时前
自己写算法(九)网页数字动画函数——东方仙盟化神期
前端·javascript·算法·仙盟创梦ide·东方仙盟·东方仙盟算法
豐儀麟阁贵4 小时前
基本数据类型
java·算法
乐迪信息6 小时前
乐迪信息:基于AI算法的煤矿作业人员安全规范智能监测与预警系统
大数据·人工智能·算法·安全·视觉检测·推荐算法
hsjkdhs7 小时前
C++之多层继承、多源继承、菱形继承
开发语言·c++·算法
立志成为大牛的小牛7 小时前
数据结构——十七、线索二叉树找前驱与后继(王道408)
数据结构·笔记·学习·程序人生·考研·算法
星空下的曙光7 小时前
Node.js crypto模块所有 API 详解 + 常用 API + 使用场景
算法·node.js·哈希算法
StarPrayers.9 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
爱吃橘的橘猫9 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
235169 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
weixin_3077791310 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json