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

做网站 前台和后台网站建设教程书籍免费下载

做网站 前台和后台,网站建设教程书籍免费下载,科技馆展厅,设计软件有哪些软件免费想要精通算法和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.w-s-a.com/news/746185/

相关文章:

  • 购书网站开发的意义网站建设接单渠道
  • 网站站内搜索怎么做wordpress默认主题修改
  • 网站推广的表现方式交网站建设 域名计入什么科目
  • 龙岗南联网站建设公司江门市
  • 网站运行方案设计平台模式
  • 网站加入wordpress邳州城乡建设局网站
  • 两个网站如何使用一个虚拟主机东莞市网站seo内容优化
  • 湖南网站建设公司排名傲派电子商务网站建设总结
  • 网站建设求职要求互联网挣钱项目平台
  • 网站权重怎么做做黑彩网站能赚钱吗
  • 三台建设局网站网页设计购物网站建设
  • thinkphp大型网站开发市场调研公司招聘
  • 天宁区建设局网站七冶建设集团网站 江苏
  • 越南网站 后缀湘潭新思维网站
  • 环球旅行社网站建设规划书网钛cms做的网站
  • 软件资源网站wordpress不能识别语言
  • 东坑仿做网站西安私人网站
  • 公司想做个网站怎么办如何搭建视频网站
  • .net网站架设凯里网站建设哪家好
  • seo网站建站建站国外百元服务器
  • 家具网站开发设计论文企业网站里面的qq咨询怎么做
  • 网站视频提取软件app淘宝店购买网站
  • 站长之家域名解析做百度推广网站咱们做
  • 行业 网站 方案莱州网站建设公司电话
  • 丹东谁做微网站威海网络科技有限公司
  • 寻找网站建设_网站外包自助打印微信小程序免费制作平台
  • 台式机网站建设vk社交网站做婚介
  • 创建网站得花多少钱网站建设的技术路线
  • 图书馆网站建设汇报免费编程软件哪个好用
  • 手机搭建网站工具网站搜索引擎优化的基本内容