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

Java | Leetcode Java题解之第546题移除盒子

题目:

题解:

class Solution {int[][][] dp;public int removeBoxes(int[] boxes) {int length = boxes.length;dp = new int[length][length][length];return calculatePoints(boxes, 0, length - 1, 0);}public int calculatePoints(int[] boxes, int l, int r, int k) {if (l > r) {return 0;}if (dp[l][r][k] == 0) {int r1 = r, k1 = k;while (r1 > l && boxes[r1] == boxes[r1 - 1]) {r1--;k1++;}dp[l][r][k] = calculatePoints(boxes, l, r1 - 1, 0) + (k1 + 1) * (k1 + 1);for (int i = l; i < r1; i++) {if (boxes[i] == boxes[r1]) {dp[l][r][k] = Math.max(dp[l][r][k], calculatePoints(boxes, l, i, k1 + 1) + calculatePoints(boxes, i + 1, r1 - 1, 0));}}}return dp[l][r][k];}
}

http://www.mrgr.cn/news/68207.html

相关文章:

  • LightGBM-GPU不能装在WSL,能装在windows上
  • J2EE平台
  • unity游戏开发之--人物打怪爆材料--拾进背包的实现思路
  • mysql数据库(三)表的完整性约束、表与表的关系
  • vue中实现列表无缝动态滚动
  • 操作系统学习笔记-3.2虚拟内存
  • 高级java每日一道面试题-2024年10月30日-JVM篇-新生代垃圾回收器和老生代垃圾回收器有哪些?有什么区别?
  • 如何实现低代码接口?低代码平台接口开发详解
  • 解决警告:Boxed value is unboxed and then immediately reboxed
  • C++:模拟实现STL的list
  • 鸿蒙NEXT开发笔记(十二)仿微信聊天App的图片转BASE64串
  • Nginx 配置文件详解
  • 【最高分数与最低分数 】
  • 理解Web登录机制:会话管理与跟踪技术解析(三)-过滤器Filter
  • 【系统设计】数据库压缩技术详解:从基础到实践(附Redis内存优化实战案例)
  • 软件测试基础十四(python 类与对象)
  • 问:SpringFramwork都有哪些模块?
  • 论文1—《基于卷积神经网络的手术机器人控制系统设计》文献阅读分析报告
  • C++学习笔记----11、模块、头文件及各种主题(一)---- 模板概览与类模板(1)
  • 网络编程(一):UDP socket api => DatagramSocket DatagramPacket
  • 对话框(Dialog)
  • W3C HTML 活动
  • [数组排序] 1122. 数组的相对排序
  • 插入迭代器
  • 口播博主必装的五个App推荐,尤其是程序猿博主
  • 查缺补漏----内部排序算法排序趟数和比较次数