【LeetCode:312. 戳气球+ 动态规划】

在这里插入图片描述

🚀 算法题 🚀

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域优质创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

🚀 算法题 🚀

在这里插入图片描述

在这里插入图片描述

🚩 题目链接

⛲ 题目描述

有 n 个气球,编号为0 到 n - 1,每个气球上都标有一个数字,这些数字存在数组 nums 中。

现在要求你戳破所有的气球。戳破第 i 个气球,你可以获得 nums[i - 1] * nums[i] * nums[i + 1] 枚硬币。 这里的 i - 1 和 i + 1 代表和 i 相邻的两个气球的序号。如果 i - 1或 i + 1 超出了数组的边界,那么就当它是一个数字为 1 的气球。

求所能获得硬币的最大数量。

示例 1:
输入:nums = [3,1,5,8]
输出:167
解释:
nums = [3,1,5,8] --> [3,5,8] --> [3,8] --> [8] --> []
coins = 315 + 358 + 138 + 181 = 167
示例 2:

输入:nums = [1,5]
输出:10

提示:

n == nums.length
1 <= n <= 300
0 <= nums[i] <= 100

🌟 求解思路&实现代码&运行结果


⚡ 动态规划

🥦 求解思路
  1. dp[i][j]表示第i至第j个元素这个区间能获得的最大硬币数,k表示在i,j这个区间内最后戳破的气球,状态转移方程dp[i][j]=max(dp[i][j],dp[i][k]+dp[k][j]+nums[i]*nums[k]*nums[j])。
  2. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
class Solution {
    public int maxCoins(int[] nums) {
        if(nums == null || nums.length == 0) {
            return 0;
        }
        int n = nums.length;
        //创建一个n+2的数组,开头和末尾都填1
        int[] arr = new int[n + 2];
        for(int i = 1; i <= n; ++i) {
            arr[i] = nums[i - 1];
        }
        arr[0]= 1;
        arr[n + 1] = 1;
        int[][] dp = new int[n + 2][n + 2];
        //从下往上遍历,i控制左边界,j控制右边界
        for(int i = n - 1; i >= 0; --i) {
            for(int j = i + 2; j <= n + 1; ++j) {
                //k在(i,j)范围内遍历气球,计算每选择一个气球的积分
                //一轮遍历完后,就能确定(i,j)的最大积分
                for(int k = i + 1; k < j; ++k) {
                    int total = arr[i] * arr[k] * arr[j];
                    total += dp[i][k] + dp[k][j];
                    dp[i][j] = Math.max(dp[i][j], total);
                }
            }
        }
        return dp[0][n + 1];
    }
}


🥦 运行结果

在这里插入图片描述


💬 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述

相关推荐

  1. LeetCode-day07-312. 气球

    2024-06-16 03:32:08       6 阅读
  2. 困难 Leetcode 312. 气球 区间dp/记忆化搜索

    2024-06-16 03:32:08       9 阅读
  3. 动态规划 Leetcode 322 零钱兑换

    2024-06-16 03:32:08       46 阅读
  4. 动态规划 Leetcode 392 判断子序列

    2024-06-16 03:32:08       12 阅读
  5. 动态规划Leetcode 322. 零钱兑换【中等】

    2024-06-16 03:32:08       9 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-16 03:32:08       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-16 03:32:08       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-16 03:32:08       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-16 03:32:08       20 阅读

热门阅读

  1. 【LeetCode 12】整数转罗马数字

    2024-06-16 03:32:08       8 阅读
  2. c++处理字符串

    2024-06-16 03:32:08       9 阅读
  3. *args和**kwargs这个在python中的意思

    2024-06-16 03:32:08       9 阅读
  4. Qt事件处理和传递流程

    2024-06-16 03:32:08       6 阅读
  5. springboot事务管理的机制是什么

    2024-06-16 03:32:08       4 阅读
  6. datalist 是什么?

    2024-06-16 03:32:08       5 阅读