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

广东华迪工程建设监理公司网站wordpress 提示-1

广东华迪工程建设监理公司网站,wordpress 提示-1,汉源网站建设,网站模板 帝国 phpcms完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i]#xff0c;得到的价值是value[i] 。每件物品都有无限个#xff08;也就是可以放入背包多次#xff09;#xff0c;求解将哪些物品装入背包里物品价值总和最大。 完全背包和01背包问题唯一不同…完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i]得到的价值是value[i] 。每件物品都有无限个也就是可以放入背包多次求解将哪些物品装入背包里物品价值总和最大。 完全背包和01背包问题唯一不同的地方就是每种物品有无限件。 同样leetcode上没有纯完全背包问题都是需要完全背包的各种应用需要转化成完全背包问题所以我这里还是以纯完全背包问题进行讲解理论和原理。 每件物品可以放入多次 为什么遍历物品在外层循环遍历背包容量在内层循环 01背包中二维dp数组的两个for遍历的先后循序是可以颠倒了一维dp数组的两个for循环先后循序一定是先遍历物品再遍历背包容量。 在完全背包中对于一维dp数组来说其实两个for循环嵌套顺序是无所谓的 因为dp[j] 是根据 下标j之前所对应的dp[j]计算出来的。 只要保证下标j之前的dp[j]都是经过计算的就可以了。 518.零钱兑换II(两次) 力扣题目链接(opens new window) 给定不同面额的硬币和一个总金额。写出函数来计算可以凑成总金额的硬币组合数。假设每一种面额的硬币有无限个。 示例 1: 输入: amount 5, coins [1, 2, 5]输出: 4 解释: 有四种方式可以凑成总金额: 55522152111511111 看到题目的第一想法 确定可以凑成dp的组合数 但是相同面额的可以重复使用完全背包 看到代码随想录之后的想法 确定dp数组以及每个下标的含义 dp[j] 为0~i之间能凑成j金额所需要的次数 i为coins下标 确定递推公式 选中coins[i] 则一共有j-coins[i]种能凑成j  再加上本身的dp[j] 就知道添加了coins[i]后一共要多少次 dp[j] dp[j] dp[j-coins[i]] 确定遍历顺序 可以重复添加物品则从前往后 dp数组初始化 dp[0]1为一切的源头其他都为0 举例推导dp数组 自己实现过程中遇到的困难 我自己写成了  max(dp[j]dp[j-weight[i]]1) 记混了 要理解组合数求的是能凑成j的数目需要累加j-coins[i] class Solution {public int change(int amount, int[] coins) {//有多少种方式可以凑成对应面额// 确定dp数组以及每个下标的的含义// 能凑成目标金额的最大个数// 确定递推公式// dp[i]dp[i-nums[i]]// dp数组初始化// dp[0]1;其他都为0// 确定遍历顺序// 从前往后因为可以重复// 手动推导dp数组// 打印dp数组int dp[] new int[amount1];dp[0]1;for(int i0;icoins.length;i){//从前往后for(int jcoins[i];jamount;j){dp[j]dp[j]dp[j-coins[i]];}}return dp[amount];} } 377. 组合总和 Ⅳ 力扣题目链接(opens new window) 难度中等 给定一个由正整数组成且不存在重复数字的数组找出和为给定目标正整数的组合的个数。 示例: nums [1, 2, 3]target 4 所有可能的组合为 (1, 1, 1, 1) (1, 1, 2) (1, 2, 1) (1, 3) (2, 1, 1) (2, 2) (3, 1) 请注意顺序不同的序列被视作不同的组合。 因此输出为 7。 看到题目的第一想法 可以凑成目标正整数的组合的个数。 和零钱兑换II差不多 看到代码随想录之后的想法 确定dp数组以及每个下标的含义 dp[j] 为0~i之间能凑成target所需要的次数 i为nums下标 确定递推公式 选中nums[i] 则一共有j-nums[i]种能凑成j  再加上本身的dp[j] 就知道添加了nums[i]后一共要多少次 dp[j] dp[j] dp[j-nums[i]] 确定遍历顺序 可以重复添加物品则从前往后 比如说 (1231) 若可以凑成target 如果先物品后背包  物品1 遍历完后  将再也不会遍历到1之后遍历的是物品234 所以必须先背包后物品 外层循环是背包容量物品按照 1 2 3 4的顺序依次遍历 则 遍历完1,2,3还能遍历回1 dp数组初始化 dp[0]1为一切的源头其他都为0 举例推导dp数组 自己实现过程中遇到的困难 需要确认组合数和排列数的区别(看代码注释) 组合数 不强调顺序不同顺序的都视为一个集合必须先物品再背包          排列数 本题不同的地方在于不同顺序的视为不同集合则必须先背包再物品          class Solution {public int combinationSum4(int[] nums, int target) {// 组合数先遍历物品再遍历背包每次选中一个物品都会遍历所有背包 1号物品一定在2号物品的前面// 排列数先遍历背包再遍历物品则每次选中一个背包都会遍历所有物品 每次都是 1号物品2号物品。。。。 // 第二次 1号物品2号物品 1 2 交替 // 确定dp数组以及对应下标的含义// 在0~i中满足总和为j的元素的个数,背包重量nums[i] 背包价值nums[i]// 确定递推公式// dp[j]dp[j-nums[i]]// dp数组的初始化// dp[0]1 // 确定遍历顺序// 可以重复 从前往后// 组合数 不强调顺序不同顺序的都视为一个集合必须先物品再背包// 排列数 本题不同的地方在于不同顺序的视为不同集合则必须先背包再物品// 手动推导dp数组int[] dp new int[target1];dp[0]1;for(int j0;jtarget;j){for(int i0;inums.length;i){if(jnums[i]){dp[j]dp[j-nums[i]];}}}return dp[target];} }
http://www.w-s-a.com/news/984871/

相关文章:

  • 凡科建站登录官网wordpress主题有什么用
  • 西安双语网站建设怎么做网页动图
  • 宝安自适应网站建设无锡新区企业网站推广
  • 肇庆建设局网站cpanel 安装wordpress
  • 长春启做网站多少怎样换wordpress域名
  • 山西网站建设情况汇总vs2010 c 建设网站
  • 网站推广策划书 精品深圳市住建局和建设局官网
  • 住房和城乡建设部干部学院网站一般做公司网站需要哪几点
  • 网站制作流程详解(学做网站第一步)免费个人网站模版ps
  • 狮山网站建设公司微信平台软件开发
  • 绥芬河网站建设学网站开发的能找什么工作
  • 网站域名申请之后如何做网站微信公众号网页版登录入口
  • 网站优化图片省级精品课程网站
  • 婚纱摄影的网站模板怎么做网站自己当站长
  • 江西建设部网站wordpress弹出式广告
  • 工商年检在哪个网站做中国建设银行个人登录
  • seo做网站郑州巩义网站建设
  • 建设银行网站机构特点业务发展网站推广工作计划
  • 国家信用信息系统年报seo推广赚钱
  • 公司建设网站价格表广州免费拍卖公司
  • 知行网站建设wordpress文章半透明
  • 建设网站的虚拟机配置建设银行宁波分行招聘网站
  • 济南网站开发xywlcn网络推广服务合同模板
  • 品牌网站制作流程图用asp做网站题目
  • 兰州市建设厅网站河南网站建设问一问公司
  • 高档网站建设前端网站大全
  • 深圳电力建设公司网站互联网网站有哪些
  • 淅川网站建设如何在百度上做自己的网站
  • 网站制作 南通有学给宝宝做衣服的网站吗
  • 做西式快餐店网站网络营销的含义是什么