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

31. 1049. 最后一块石头的重量 II, 494.目标和,474.一和零

class Solution {
public:int lastStoneWeightII(vector<int>& stones) {int sum = 0;for(int stone : stones) sum += stone;int bagSize = sum /2;vector<int> dp(bagSize + 1, 0);for(int i = 0; i < stones.size(); i++){ //遍历物品for(int j = bagSize; j >= stones[i]; j--){ //遍历背包dp[j] = max(dp[j], dp[j - stones[i]] + stones[i]);}}return sum - 2*dp[bagSize];}
};

class Solution {
public:int findTargetSumWays(vector<int>& nums, int target) {int ans = 0, sum = 0;for(int num : nums) sum += num;if((sum - target) % 2 != 0 || abs(sum) < abs(target)) return 0;int bagSize = (sum - target)/2;// dp[j] 表示:填满j(包括j)这么大容积的包,有dp[j]种方法vector<int> dp(bagSize + 1, 0);dp[0] = 1;for(int i = 0; i < nums.size(); i++){for(int j = bagSize; j >= nums[i]; j--){dp[j] += dp[j - nums[i]]; //注意理解递推公式!!!!!!}  }return dp[bagSize];}
};

本题中strs 数组里的元素就是物品,每个物品都是一个!而m 和 n相当于是一个背包,两个维度的背包 注意理解题目中最大子集长度的含义!!!!!!

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {// dp[i][j]:最多有i个0和j个1的strs的最大子集的大小为dp[i][j]。vector<vector<int>> dp(m + 1, vector<int>(n + 1, 0)); //默认初始化0for(string str : strs){ //遍历物品int zeroNum = 0, oneNum= 0;for(char c : str){if(c == '0') zeroNum++;else oneNum++;}for(int i = m; i >= zeroNum; i--){ //遍历背包容量且从后向前遍历!for(int j = n; j >= oneNum; j--){dp[i][j] = max(dp[i][j], dp[i - zeroNum][j - oneNum] + 1);}}}return dp[m][n];}
};

 

http://www.lryc.cn/news/398266.html

相关文章:

  • PDF 中图表的解析探究
  • 递推(C语言)
  • 安卓微信8.0之后如何利用缓存找回的三天之前不可见的朋友圈图片
  • ES6 Class(类) 总结(九)
  • 使用 Vue.js 和 Element Plus 实现自动完成搜索功能
  • SpringBoot自定义starter
  • 深入探索大语言模型
  • querylist多线程采集curlMulti时,报错Curl error(60)
  • Python数据分析~~美食排行榜
  • Linux下解压.tar.gz文件
  • 【电商选品干货】差异化卖点要这样打造,80%商家却做不到
  • LabVIEW比例压力控制阀自动测试系统
  • 运营商认证API在Java、Python、PHP中的使用教程
  • 用虚拟机,可以在x86的电脑上虚拟出arm的电脑吗
  • 富格林:可信观念摆脱暗箱陷阱
  • WEB前端01-HTML5基础(01)
  • JUC-常见方法与线程的状态
  • 如果你酿的酒是黄色,说明肯定是 “糊锅”了。
  • 国漫推荐07
  • 力扣刷题35.搜索查找位置
  • setContentView 流程
  • 基于STM32设计的智能手环(ESP8266+华为云IOT)178
  • EE trade:实物黄金投资的好处和坏处
  • Flutter RSA公钥转PEM
  • 下载站怎么防护DDOS攻击
  • docker拉取镜像-配置阿里云镜像加速
  • ai写作软件哪个好?亲测好用的5款工具分享
  • Blender 中导出模型fbx
  • 景联文科技以高质量多模态数据集赋能AI大模型,精准匹配提升模型性能
  • 【ROS2】中级:tf2-编写监听器(Python)