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

哪些网站可以下载视频哈尔滨网站建设价格低

哪些网站可以下载视频,哈尔滨网站建设价格低,2003建立虚拟网站,东莞网络优化哪家强想要精通算法和SQL的成长之路 - 填充书架 前言一. 填充书架1.1 优化 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 填充书架 原题链接 题目中有一个值得注意的点就是#xff1a; 需要按照书本顺序摆放。每一层当中#xff0c;只要厚度不够了#xff0c;当前层最高… 想要精通算法和SQL的成长之路 - 填充书架 前言一. 填充书架1.1 优化 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 填充书架 原题链接 题目中有一个值得注意的点就是 需要按照书本顺序摆放。每一层当中只要厚度不够了当前层最高的那一本书籍就视为本层的高度。 那么我们假设dp[i] 代表从 book[0] 摆到 book[i] 的时书架的最小高度。 假设最后一层的第一本书的下标是 j那么之前所有书本摆放的最小高度就是 dp[j-1]。我们再计算出下标在[j,i]最后一层的书本中高度最高的那一本书同时满足厚度不超过shelfWidth高度为maxHeight。那么当前的最小总高度是 res Max(dp[i-1]maxHeightres)。即之前的总高度最后一层的最高高度。 我们递归从后往前递归。入参为遍历的书本下标。 终止条件下标 0。代表没有书本了停止递归。递归做的事情循环[0,i]之间的所有元素从后往前把书本放入最后一层一旦厚度超出终止遍历。否则计算当前层的最高高度以及最小总高。 public class Test1105 {public int[][] books;public int shelfWidth;public int minHeightShelves(int[][] books, int shelfWidth) {this.books books;this.shelfWidth shelfWidth;return dfs(books.length - 1);}public int dfs(int i) {// 终止条件if (i 0) {return 0;}int res Integer.MAX_VALUE, maxHeight 0, width shelfWidth;for (int j i; j 0; j--) {// 从后往前放书本width - books[j][0];// 厚度不能超过 shelfWidth 超过就代表放不下了if (width 0) {break;}// 当前层最高高度maxHeight Math.max(maxHeight, books[j][1]);// 更新总最低书架高度 上层最小总高度 当前层最高高度res Math.min(res, dfs(j - 1) maxHeight);}return res;} }这个解答其实对于用例比较多的情况是会超时的。 1.1 优化 我们来看下上面代码的不好的点 每次dfs的时候循环的范围是[0,j]。循环内部又每次调用了dfs递归即dfs[j-1]。 整个递归函数只用到了一个索引的参数我们可以发现索引为1,2,3…的递归被重复调用了非常多次。以当前索引为3为例 第一次递归范围[0,3]。第二次递归范围[0,2]。第三次递归范围[0,1]。… 那么我们可以用一个全局的变量去记录每次dfs返回的结果即可: public class Test1105 {public int[][] books;public int shelfWidth;// 缓存dfs的结果public int[] dfsCache;public int minHeightShelves(int[][] books, int shelfWidth) {this.books books;this.shelfWidth shelfWidth;// 初始化dfsCache new int[books.length];// 给个初始值-1代表没有被执行过即没有缓存Arrays.fill(dfsCache, -1);return dfs(books.length - 1);}public int dfs(int i) {// 终止条件if (i 0) {return 0;}// 如果是-1代表这层值没有执行过往下走。否则说明有缓存了直接返回if (dfsCache[i] ! -1) {return dfsCache[i];}int res Integer.MAX_VALUE, maxHeight 0, width shelfWidth;for (int j i; j 0; j--) {// 从后往前放书本width - books[j][0];// 厚度不能超过 shelfWidth 超过就代表放不下了if (width 0) {break;}// 当前层最高高度maxHeight Math.max(maxHeight, books[j][1]);// 更新总最低书架高度 上层最小总高度 当前层最高高度res Math.min(res, dfs(j - 1) maxHeight);}// 缓存下当前结果dfsCache[i] res;return dfsCache[i];} }
http://www.lakalapos1.cn/news/19922/

相关文章:

  • 陕西网站开发企业佛山设计网站
  • 公司网站开发策略和基本步骤wordpress获取文章信息
  • 为什么要进行电子商务网站规划国家企业信用信息查询官网
  • 余姚网站建设哪家好3d网站制作
  • 基于jsp的社团组织网站建设中企动力百度百科
  • 如何做网站内链优化谷歌网站推广优化
  • 二十一冶建设有限公司网站衬衫定做公司
  • 中国美院网站建设公司wordpress 瀑布流模板
  • 网站建设微商城长春商城网站建设
  • 家教网站如何做自己制作网站做外贸赚钱吗
  • 个人网站做经营性初学者拟建网站
  • .net 响应式网站visual composer for wordpress
  • 投资网站排行大航母网站建设案例
  • 项目网站制作海外推广
  • 个人网站制作的步骤wordpress 添加中文字体
  • 电子商务在线网站建设手机商城及手机价格
  • 东莞做网站软件做音乐网站的条件
  • 灵璧零度网站建设php使用wordpress
  • 彩票网站 建设网站建设美工百度百科
  • 龙华做网站的中国建设银行网站下载安装
  • wordpress 站点网络公众号运营一年多少钱
  • 云浮+网站建设网站所有二级目录
  • 迷你主机做网站wordpress和织梦哪个好
  • 淮南品牌网站建设电话郑州网站设计排行
  • 佰维网站建设前端基础知识
  • 网站建设价格方案页面设计公司会招低学历的人吗
  • 承德市建设局网站潜江资讯网房屋出租
  • 游戏公司官方网站建设方案小米网站开发流程书
  • 湖南网站建设的公司排名那些提卡网站是怎么做的
  • 网站流量的作用wordpress有什么有趣的插件