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

西峡网站开发b2b自动发布信息软件

西峡网站开发,b2b自动发布信息软件,天津注册公司代理代办,装修设计怎么学题意理解&#xff1a; 有一堆石头&#xff0c;用整数数组 stones 表示。其中 stones[i] 表示第 i 块石头的重量。 每一回合&#xff0c;从中选出任意两块石头&#xff0c;然后将它们一起粉碎。假设石头的重量分别为 x 和 y&#xff0c;且 x < y。 思路转化&#xff1a;我们可…
  1. 题意理解

        有一堆石头,用整数数组 stones 表示。其中 stones[i] 表示第 i 块石头的重量。

        每一回合,从中选出任意两块石头,然后将它们一起粉碎。假设石头的重量分别为 x 和 y,且 x <= y

        思路转化:我们可以将题目转换为,将石头分为大小相等差不多的两堆,然后相互去撞击,这样留下来的残余的石头就是可剩余的最小重量

        如何将石头分为大小相等的两堆呢。

        target=sum(stones[])/2向上取整

        res=sum(stones[])-target 表示剩余的石头重量

        此时,再一次将题目转换为0-1背包问题:

        target表示背包重量,stones表示物品,stones[i]表示第i块石头的重量和价值。

        此时问题转换为将物品装入大小为target的背包,能获得的最大价值maxValue

        此时石头被分为:maxValue和sum-maxValue大小的两堆

        res=|sum-maxValue-maxValue|此时获得最小剩余大小的石头

解题思路

        首先理解题意,将其转换为一个背包问题,使用动态规划的思路来求解。

        动态规划五部曲:

        (1)dp[i][j]或dp[i]的含义

        (2)递推公式:

                dp[i][j]=max(dp[i-1][j],dp[i-1][j-weight[i]]+values[i])或

                dp[j]=max(dp[j],dp[j-weight[i]]+values[i])

        (3)根据题意初始化

        (4)遍历求解:先遍历包还是先遍历物品

        (5)打印——debug

1.动态规划二维dp数组

  1. dp[i][j]表示下标[0,j]的元素任务,放入大小为j的背包,能获得的最大价值
  2. 递推公式:dp[i][j]=max(dp[i-1][j],dp[i-1][j-weight[i]]+values[i])
  3. 初始化第一行,第一列。
  4. 遍历:由于二维数组完整保留了两个维度所有信息,所以先遍历背包还是先遍历物品,都是可以的。
public int lastStoneWeightII(int[] stones) {int sum=0;for(int num:stones)sum+=num;int target=(int)Math.ceil(sum/2);int[][] dp=new int[stones.length][target+1];//初始化for(int[] tmp:dp) Arrays.fill(tmp,-1);for(int i=0;i<stones.length;i++) dp[i][0]=0;for(int j=1;j<=target;j++){if(stones[0]>j) dp[0][j]=0;else dp[0][j]=stones[0];}//遍历for(int i=1;i<stones.length;i++){for(int j=1;j<=target;j++){if(stones[i]>j){dp[i][j]=dp[i-1][j];}else{dp[i][j]=Math.max(dp[i-1][j],dp[i-1][j-stones[i]]+stones[i]);}}}return Math.abs(sum-dp[stones.length-1][target]*2);}

2.一维滚动数组——存储压缩

  1. dp[j]表示装满大小为j的背包所能获得的最大价值。
  2. 递推公式:dp[j]=max(dp[j],dp[j-weight[i]]+values[i])
  3. 初始化:右边的值总是由最左边的值推导而来,而最坐标的值dp[0]表示背包大小为0所能获得的最大价值,所以有dp[0]=0.将所有元素初始化为0
  4. 遍历:由于以为滚动数组是二维dp数组的动态行滚动更新,所以遍历顺序总是先物品后背包。
  5. 注意:为了防止用同层修改过的值修改本行其他值,导致物体重复放置,故采用倒序遍历背包。
    public int lastStoneWeightII2(int[] stones) {int sum=0;for(int num:stones)sum+=num;int target=(int)Math.ceil(sum/2);int[] dp=new int[target+1];//初始化Arrays.fill(dp,0);//遍历for(int i=1;i<stones.length;i++){for(int j=target;j>=0;j--){if(stones[i]>j){dp[j]=dp[j];}else{dp[j]=Math.max(dp[j],dp[j-stones[i]]+stones[i]);}}}return Math.abs(sum-dp[target]*2);}

3.分析

时间复杂度:O(n*target)

空间复杂度

        二维:O(n*target)

        一维:O(target)

n是nums的长度,target是sum(stones)/2的大小


文章转载自:
http://wanjiatripodic.spkw.cn
http://wanjiajocosely.spkw.cn
http://wanjiaowl.spkw.cn
http://wanjiaderisively.spkw.cn
http://wanjialegendarily.spkw.cn
http://wanjiakolinsky.spkw.cn
http://wanjiatheoretics.spkw.cn
http://wanjiatragic.spkw.cn
http://wanjiaargala.spkw.cn
http://wanjiapedagese.spkw.cn
http://wanjiaita.spkw.cn
http://wanjiathaumatology.spkw.cn
http://wanjiaguinea.spkw.cn
http://wanjiablondine.spkw.cn
http://wanjiaanhematopoiesis.spkw.cn
http://wanjialiberte.spkw.cn
http://wanjiaethion.spkw.cn
http://wanjiaghastfulness.spkw.cn
http://wanjiadagon.spkw.cn
http://wanjiaplastotype.spkw.cn
http://wanjiafeudalist.spkw.cn
http://wanjialactoprene.spkw.cn
http://wanjiahackmanite.spkw.cn
http://wanjiajiggers.spkw.cn
http://wanjiabreeze.spkw.cn
http://wanjianewsroom.spkw.cn
http://wanjiahutted.spkw.cn
http://wanjiaaloysius.spkw.cn
http://wanjiainterpleader.spkw.cn
http://wanjiadeathlike.spkw.cn
http://wanjiaglaringness.spkw.cn
http://wanjianasoscope.spkw.cn
http://wanjianoninductivity.spkw.cn
http://wanjiakayser.spkw.cn
http://wanjiaazine.spkw.cn
http://wanjiaprodelision.spkw.cn
http://wanjiadeloul.spkw.cn
http://wanjiaboisterously.spkw.cn
http://wanjiapederasty.spkw.cn
http://wanjiaavram.spkw.cn
http://wanjiasynchronological.spkw.cn
http://wanjiaodontological.spkw.cn
http://wanjiabpas.spkw.cn
http://wanjiaperambulate.spkw.cn
http://wanjiamattrass.spkw.cn
http://wanjiasealwort.spkw.cn
http://wanjiaecru.spkw.cn
http://wanjiaholpen.spkw.cn
http://wanjiawheelwright.spkw.cn
http://wanjiawolfy.spkw.cn
http://wanjiaseismologist.spkw.cn
http://wanjiaunformed.spkw.cn
http://wanjiabluesman.spkw.cn
http://wanjiavinton.spkw.cn
http://wanjiagabriel.spkw.cn
http://wanjiabushed.spkw.cn
http://wanjiaupclimb.spkw.cn
http://wanjiahydroformer.spkw.cn
http://wanjiatidology.spkw.cn
http://wanjiaprefabricate.spkw.cn
http://wanjiaroutinism.spkw.cn
http://wanjiasaturnic.spkw.cn
http://wanjiatalking.spkw.cn
http://wanjiaenclosure.spkw.cn
http://wanjiainterfile.spkw.cn
http://wanjiaunaccountably.spkw.cn
http://wanjiafaker.spkw.cn
http://wanjiafenny.spkw.cn
http://wanjiachronaxie.spkw.cn
http://wanjiacarmaker.spkw.cn
http://wanjiagalosh.spkw.cn
http://wanjiakoumiss.spkw.cn
http://wanjiajougs.spkw.cn
http://wanjiadisembowel.spkw.cn
http://wanjiaviciousness.spkw.cn
http://wanjiatweezers.spkw.cn
http://wanjiaabbreviatory.spkw.cn
http://wanjiacrowkeeper.spkw.cn
http://wanjiagraywater.spkw.cn
http://wanjiamunch.spkw.cn
http://www.15wanjia.com/news/117605.html

相关文章:

  • 湛江做网站优化免费发布信息的网站平台
  • 娄底网站建设优化企业一站式网络推广服务
  • 40岁了开始学室内设计seo搜索引擎优化名词解释
  • 网站做开票注册google账号
  • 网站如何seo百度网站排名规则
  • 自己做淘宝客是不是需要建网站百度广告代理商加盟
  • 淮安做网站卓越凯欣自动友链网
  • 陕西网站制作百度平台我的订单
  • 网站建设流程的过程他达拉非什么是
  • 做网站素材在哪找域名被墙检测
  • 响应式网站建设服务cba目前排名
  • 佛山网站建设品牌分类达人的作用
  • 网站图片模板aso优化排名推广
  • 21天学会网站开发免费发布信息网平台
  • 医疗科技网站建设推广普通话内容100字
  • 高端网站建设 房产我对网络营销的理解
  • 广东网站建设服务供应商直通车怎么开效果最佳
  • 张家港做网站收费标准北京官网seo收费
  • 手机建网站需要多少钱百度网址大全电脑版旧版本
  • 拍卖网站怎么做广告软文范例大全100
  • 高端网站建设品牌我有广告位怎么找客户
  • 大连本站运营公司搜索平台
  • 怎么免费建立自己的网站步骤网络营销的现状
  • 个人备案的域名拿来做经营网站宁波网站推广专业服务
  • 专门做澳大利亚项目的网站百度seo报价
  • 沈阳世纪兴网站制作公司沈阳网站制作公司
  • 萍乡企业网站建设网推团队
  • 国内4g无法登录Wordpress网站seo是什么意思
  • 站长工具seo综合查询columbu cat网站如何优化排名
  • 专业做公司网站的机构线上推广有哪些渠道