LeetCode //C - 216. Combination Sum III

216. Combination Sum III

Find all valid combinations of k numbers that sum up to n such that the following conditions are true:

  • Only numbers 1 through 9 are used.
  • Each number is used at most once.

Return a list of all possible valid combinations. The list must not contain the same combination twice, and the combinations may be returned in any order.

Example 1:

Input: k = 3, n = 7
Output: [[1,2,4]]
Explanation:

1 + 2 + 4 = 7

There are no other valid combinations.

Example 2:

Input: k = 3, n = 9
Output: [[1,2,6],[1,3,5],[2,3,4]]
Explanation:

1 + 2 + 6 = 9

1 + 3 + 5 = 9

2 + 3 + 4 = 9

There are no other valid combinations.

Example 3:

Input: k = 4, n = 1
Output: []
Explanation: There are no valid combinations.

Using 4 different numbers in the range [1,9], the smallest sum we can get is 1+2+3+4 = 10 and since 10 > 1, there are no valid combination.

Constraints:
  • 2 <= k <= 9
  • 1 <= n <= 60

From: LeetCode

Link: 216. Combination Sum III


Solution:

Ideas:
  • Dynamic Capacity: The capacity for storing combinations is initially set and then doubled as needed. This prevents overflow by ensuring there's always enough space for new combinations.
  • Safe Memory Operations: All memory allocations and accesses are carefully managed to ensure they stay within bounds. This includes checking capacity before adding new combinations and correctly allocating and freeing memory.
  • Base Case Check: The base case in the backtrack function ensures that we only add valid combinations that meet the criteria (sum equals n and combination length equals k).
Caode:
c 复制代码
void backtrack(int target, int k, int start, int* path, int depth, int*** res, int* resSize, int** colSizes, int* capacity) {
    // Base case: if the combination is complete
    if (depth == k) {
        if (target == 0) {
            // If current path sums up to n, add it to the results
            if (*resSize >= *capacity) {
                // Double the capacity if necessary
                *capacity *= 2;
                *res = realloc(*res, *capacity * sizeof(int*));
                *colSizes = realloc(*colSizes, *capacity * sizeof(int));
            }
            (*res)[*resSize] = (int*)malloc(k * sizeof(int));
            for (int i = 0; i < k; i++) {
                (*res)[*resSize][i] = path[i];
            }
            (*colSizes)[*resSize] = k;
            (*resSize)++;
        }
        return;
    }
    
    for (int i = start; i <= 9; i++) {
        if (i > target) break; // Early termination
        path[depth] = i; // Choose
        backtrack(target - i, k, i + 1, path, depth + 1, res, resSize, colSizes, capacity); // Explore
        // No need to explicitly "unchoose", as path[depth] will be overwritten in the next iteration
    }
}

int** combinationSum3(int k, int n, int* returnSize, int** returnColumnSizes) {
    int capacity = 128; // Initial capacity for results
    int** res = (int**)malloc(capacity * sizeof(int*));
    *returnColumnSizes = (int*)malloc(capacity * sizeof(int));
    *returnSize = 0;

    int* path = (int*)malloc(k * sizeof(int)); // Temp storage for the current combination
    backtrack(n, k, 1, path, 0, &res, returnSize, returnColumnSizes, &capacity);
    
    free(path); // Cleanup
    return res;
}
相关推荐
闭月之泪舞18 分钟前
初识函数------了解函数的定义、函数的参数、函数的返回值、说明文档的书写、函数的嵌套使用、变量的作用域(全局变量与局部变量)
python·算法·机器学习
GUIQU.39 分钟前
【每日一题丨2025年5.12~5.18】排序相关题
算法·排序·每日一题
哪 吒1 小时前
2025B卷 - 华为OD机试七日集训第2期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷
孤寂大仙v1 小时前
【Linux笔记】——Linux线程封装
linux·笔记·算法
欧先生^_^2 小时前
Rust 编程语言的官方源码仓库
开发语言·算法·rust
程序员爱钓鱼2 小时前
可变参数(Variadic Functions)- 《Go语言实战指南》
算法
鸡鸭扣2 小时前
leetcode hot100:解题思路大全
数据结构·python·算法·leetcode·力扣
顾子茵2 小时前
游戏开发实战(一):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】
python·算法·游戏
被AI抢饭碗的人3 小时前
算法题(150):拼数
数据结构·算法
知识漫步3 小时前
代码随想录算法训练营第60期第三十九天打卡
算法