当前位置: 首页 > article >正文

代码随想录算法训练营第34天|46. 携带研究材料、416. 分割等和子集

文章目录

  • 46. 携带研究材料
  • 416. 分割等和子集

46. 携带研究材料

卡码网 46. 携带研究材料
代码随想录

dp[i][j]表示,考虑到第i个物品的情况下,背包容量为j的最大价值。

m, n = map(int, input().split(" "))
costs = list(map(int, input().split(" ")))
values = list(map(int, input().split(" ")))


# 二维背包
dp = [[0]*(n+1) for _ in range(m)]

for i in range(costs[0],(n+1),1):
    dp[0][i] = values[0]

for i in range(1,m):
    for j in range((n+1)):
        if j < costs[i]:
            dp[i][j] = dp[i-1][j]
        else:
            dp[i][j] = max(dp[i-1][j], dp[i-1][j-costs[i]] + values[i])
    
print(dp[m-1][n])
# print(input())
m, n = map(int, input().split(" "))
costs = list(map(int, input().split(" ")))
values = list(map(int, input().split(" ")))

# 一维背包
dp = [0] * (n+1)

for i in range(m):
    for j in range(n,costs[i]-1,-1):
        if j >= costs[i]:
            dp[j] = max(dp[j], dp[j-costs[i]] + values[i])
    
print(dp[n])

416. 分割等和子集

leetcode 416. 分割等和子集
代码随想录

找是否有满足sum(nums)/2的组合,最终的容量和价值都为这个值。

class Solution:
    def canPartition(self, nums: List[int]) -> bool:
        num_sum = sum(nums)
        target = 0
        if num_sum%2 != 0:
            return False
        else:
            target = int(num_sum / 2)
        dp = [0] * 10001
        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[target] == target:
            return True
        return False 

http://www.kler.cn/a/326960.html

相关文章:

  • Python 继承、多态、封装、抽象
  • 为啥学习数据结构和算法
  • 使用GetX实现GetPage中间件
  • 【Nginx】编译安装(Centos)
  • git 与当前代码的修改进行重新合并
  • 【解决办法】无法使用右键“通过VSCode打开文件夹”
  • Android 12系统源码_输入系统(三)输入事件的加工和分发
  • Spring RestTemplate 升级 WebClient 导致 OutOfMemoryError
  • SQL进阶技巧:如何利用if语句简化where或join中的条件 | if条件语句的优雅使用方法
  • QT界面制作
  • 粉丝们得以一窥索菲亚罗兰奢华的90岁生日庆祝仪式! 她已完成了所有的遗愿清单 !
  • 选择租用徐州存储服务器有什么作用?
  • 大数据-149 Apache Druid 基本介绍 技术特点 应用场景
  • 2024年7月大众点评广州美食店铺基础信息
  • 2024.9.24 作业
  • Stable Diffusion 蒙版:填充、原图、潜空间噪声(潜变量噪声)、潜空间数值零(潜变量数值零)
  • 我店生活系统小程序开发功能解析
  • uniapp框架中实现文件选择上传组件,可以选择图片、视频等任意文件并上传到当前绑定的服务空间
  • 修改 idea 的 Terminal 命令窗口使用 git-bash
  • 得物App荣获新奖项,科技创新助力高质量发展
  • 国内ChatGPT镜像网站整理汇总【OpenAI o1/GPT 4o】-2024/10月最新
  • 【数据结构与算法】算法和算法分析
  • nginx服务介绍
  • ros2 colcon build 构建后,install中的local_setup.bash 和setup.bash有什么区别
  • 企业数据可视化大屏的工具选择有哪些
  • UI设计师面试整理-设计趋势和行业理解