当前位置: 首页 > 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/news/326960.html

相关文章:

  • 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设计师面试整理-设计趋势和行业理解
  • 互斥量mutex、锁、条件变量和信号量相关原语(函数)----很全
  • 从两个 Excel 表格中提取相关信息,并根据学生的 学号 和 姓名 将第一个表格中的成绩数据填充到第二个表格中(附Python代码)
  • 【LeetCode HOT 100】详细题解之链表篇
  • 【Kubernetes】常见面试题汇总(四十八)
  • MySQL实现跨服务器查询
  • Vscode超好看的渐变主题插件
  • Axure9破解
  • MySQL中的嵌套查询
  • Go实现RabbitMQ消息模式
  • 科研绘图系列:R语言堆积图(stacked barplot)