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

leetcode:1049. 最后一块石头的重量 II[01背包][动态规划]

学习要点

  1. 进一步熟悉01背包
  2. 灵活转换问题

题目链接

        1049. 最后一块石头的重量 II - 力扣(LeetCode)

题目描述

解法:01背包

class Solution {
public:int lastStoneWeightII(vector<int>& stones) {int n = stones.size();int sum = accumulate(stones.begin(),stones.end(),0);int avg = sum / 2;vector<vector<int>> dp(n,vector<int>(avg+1));for(int i = 0;i<=avg;i++){if(i >= stones[0]){dp[0][i] = stones[0];}}for(int i =1;i<n;i++){for(int j = 1; j<=avg;j++){if(j < stones[i]){dp[i][j] = dp[i-1][j];}else{dp[i][j] = max(dp[i-1][j],dp[i-1][j-stones[i]] + stones[i]);}}}int a = dp[n-1][avg];int b = sum -a;return abs(a-b);}
};

http://www.dtcms.com/a/265801.html

相关文章:

  • 实际开发如何快速定位和解决死锁?
  • PM2.5和PM10分别是什么
  • 基于MATLAB的风力发电机无人机巡检路径优化研究
  • 最新PDF转markdown软件MonkeyOCR整合包,文档图片解析工具
  • 深度解析:Java内部类与外部类的交互机制
  • odoo-057 pgadmin 登录忘记密码
  • 【实时Linux实战系列】实时以太网与 TSN 基础
  • ARM单片机启动流程(二)(详细解析)
  • UDP服务器主要是指什么意思?
  • 提升自动驾驶导航能力:基于深度学习的场景理解技术
  • Centrifugo 深度解析:构建高性能实时应用的开源引擎
  • RocketMQ-Dashboard页面报Failed to fetch ops home page data错误
  • 车载交换机动态MAC学习和静态MAC绑定如何获取MAC地址表
  • BitsAndBytesConfig量化及注意事项
  • 明远智睿H618:开启多场景智慧生活新时代
  • 代码随想录打卡第五天
  • TinyWebserver学习(8)-定时器
  • 深度解析:venv和conda如何解决依赖冲突难题
  • 使用netstat与grep命令结合批量查找特定内容
  • Class3图像分类数据集代码
  • 数学建模_时间序列
  • CTF Web PHP弱类型与进制绕过(过滤)
  • 【云计算】企业项目 策略授权
  • 网络层:ip协议 与数据链路层
  • C++反射之获取可调用对象的详细信息
  • 《Spring 中上下文传递的那些事儿》Part 2:Web 请求上下文 —— RequestContextHolder 与异步处理
  • 低代码实战训练营教学大纲 (10天)
  • Linux之Socket 编程 UDP
  • 自然光实时渲染~三维场景中的全局光照
  • osg加入实时光照SilverLining 天空和3D 云