LeetCode //C - 312. Burst Balloons

312. Burst Balloons

You are given n balloons, indexed from 0 to n - 1. Each balloon is painted with a number on it represented by an array nums. You are asked to burst all the balloons.

If you burst the i t h i^{th} ith balloon, you will get numsi - 1 * numsi * numsi + 1 coins. If i - 1 or i + 1 goes out of bounds of the array, then treat it as if there is a balloon with a 1 painted on it.

Return the maximum coins you can collect by bursting the balloons wisely.

Example 1:

Input: nums = 3,1,5,8
Output: 167
Explanation

nums = 3,1,5,8 --> 3,5,8 --> 3,8 --> 8 --> \[\]

coins = 31 5 + 35 8 + 13 8 + 181 = 167

Example 2:

Input: nums = 1,5
Output: 10

Constraints:
  • n == nums.length
  • 1 <= n <= 300
  • 0 <= numsi <= 100

From: LeetCode

Link: 312. Burst Balloons


Solution:

Ideas:
  • newNums: We create a new array newNums with additional 1s at the boundaries, which simplifies edge cases where we deal with the first or last balloon.

  • Dynamic Programming (dp): We use a 2D array dp where dpleftright represents the maximum coins that can be collected from bursting all the balloons between left and right (exclusive).

  • Window Size Iteration: We iterate over all possible lengths (len) of subarrays and calculate the maximum coins that can be obtained by bursting balloons in that subarray.

  • Time Complexity: The algorithm runs in O(n^3) time due to the triple nested loop, which is efficient enough given the constraints.

Code:
c 复制代码
int maxCoins(int* nums, int numsSize) {
    // Create a new array with 1s at the boundaries
    int* newNums = (int*)malloc((numsSize + 2) * sizeof(int));
    newNums[0] = 1;
    newNums[numsSize + 1] = 1;
    for (int i = 1; i <= numsSize; i++) {
        newNums[i] = nums[i - 1];
    }
    
    int n = numsSize + 2;
    int** dp = (int**)malloc(n * sizeof(int*));
    for (int i = 0; i < n; i++) {
        dp[i] = (int*)calloc(n, sizeof(int));
    }
    
    for (int len = 2; len < n; len++) { // len is the window size
        for (int left = 0; left < n - len; left++) {
            int right = left + len;
            for (int i = left + 1; i < right; i++) {
                dp[left][right] = fmax(dp[left][right], newNums[left] * newNums[i] * newNums[right] + dp[left][i] + dp[i][right]);
            }
        }
    }
    
    int result = dp[0][n - 1];
    
    for (int i = 0; i < n; i++) {
        free(dp[i]);
    }
    free(dp);
    free(newNums);
    
    return result;
}
相关推荐
程序员zgh2 分钟前
C++ 万能引用与完美转发
c语言·开发语言·c++·经验分享·学习
智者知已应修善业2 分钟前
【51单片机串口通信甲机四个按键模拟四位二进制值发送乙机以十进制显示2位数码管】2024-6-14
c++·经验分享·笔记·算法·51单片机
KobeSacre2 分钟前
划分为k个相等的子集
算法·leetcode·深度优先
不会就选b4 分钟前
算法日常・每日刷题--<二分查找>2
算法
郝学胜_神的一滴10 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
数据结构·算法
coding者在努力11 分钟前
【无标题】
算法
兰令水14 分钟前
leecodecode【面试150】【2026.6.15打卡-java版本】
java·算法·面试
WWW652633 分钟前
代码随想录 打卡第五十八天
开发语言·c++·算法
pen-ai35 分钟前
【HistGBM 系列①】从决策树到梯度提升 —— GBDT 原理精讲
算法·决策树·机器学习
Black蜡笔小新43 分钟前
零代码私有化自动化AI算法训练服务器DLTM如何破解企业AI落地难题
人工智能·算法·自动化