力扣面试题 42 - 幂集 C语言解法 回溯算法

题目:

幂集。编写一种方法,返回某集合的所有子集。集合中不包含重复的元素

说明:解集不能包含重复的子集。

示例:

复制代码
 输入: nums = [1,2,3]
 输出:
[
  [3],
  [1],
  [2],
  [1,2,3],
  [1,3],
  [2,3],
  [1,2],
  []
]

思路:

  1. 如果我们需要求{a,b,c}的子集,那么我们需要先求出{a,b}的子集
  2. {a,b,c}的子集即为:c分别加入{a,b}的每个子集再加上{a,b}的子集
  3. 采用回溯+递归的算法,具体方法是遍历集合的每个元素,对于每个元素,我们可以选择将它加入当前子集或不加入,然后递归地生成所有可能的子集

C语言代码:

cpp 复制代码
/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */

// 回溯函数,用于生成子集
void backtrack(int* nums, int numsSize, int start, int* tempList, int tempSize, 
               int*** result, int* returnSize, int** returnColumnSizes) {
    // 将当前子集添加到结果中
    (*result) = realloc(*result, (*returnSize + 1) * sizeof(int*));  // 动态扩展结果数组
    (*result)[*returnSize] = (int*)malloc(tempSize * sizeof(int));  // 分配空间存储子集
    for (int i = 0; i < tempSize; i++) {
        (*result)[*returnSize][i] = tempList[i];  // 复制子集内容
    }
    *returnColumnSizes = realloc(*returnColumnSizes, (*returnSize + 1) * sizeof(int));  // 动态扩展列大小数组
    (*returnColumnSizes)[*returnSize] = tempSize;  // 记录当前子集的大小
    (*returnSize)++;

    // 遍历后续元素生成子集
    for (int i = start; i < numsSize; i++) {
        tempList[tempSize] = nums[i];  // 将当前元素加入子集
        backtrack(nums, numsSize, i + 1, tempList, tempSize + 1, result, returnSize, returnColumnSizes);  // 通过递序深入
    }
}

// 主函数,生成所有子集
int** subsets(int* nums, int numsSize, int* returnSize, int** returnColumnSizes) {
    *returnSize = 0;  // 初始化子集数量
    int** result = NULL;  // 存储所有子集
    *returnColumnSizes = NULL;  // 初始化每个子集大小的数组
    int* tempList = (int*)malloc(numsSize * sizeof(int));  // 临时数组存储当前子集

    // 回溯生成子集
    backtrack(nums, numsSize, 0, tempList, 0, &result, returnSize, returnColumnSizes);

    free(tempList);  // 释放临时数组
    return result;  // 返回所有子集
}
相关推荐
ゞ 正在缓冲99%…4 分钟前
leetcode1771.由子序列构造的最长回文串长度
数据结构·算法·leetcode
多喝开水少熬夜21 分钟前
堆相关算法题基础-java实现
java·开发语言·算法
锂享生活25 分钟前
论文阅读:铁路车辆跨临界 CO₂ 空调系统模型预测控制(MPC)策略
论文阅读·算法
三品吉他手会点灯33 分钟前
STM32F103学习笔记-16-RCC(第3节)-使用HSE配置系统时钟并使用MCO输出监控系统时钟
c语言·笔记·stm32·单片机·嵌入式硬件·学习
B站_计算机毕业设计之家34 分钟前
深度学习:Yolo水果检测识别系统 深度学习算法 pyqt界面 训练集测试集 深度学习 数据库 大数据 (建议收藏)✅
数据库·人工智能·python·深度学习·算法·yolo·pyqt
jzhwolp1 小时前
从nginx角度看数据读写,阻塞和非阻塞
c语言·nginx·性能优化
骑自行车的码农1 小时前
React SSR 技术实现原理
算法·react.js
盘古开天16661 小时前
深度强化学习算法详解:从理论到实践
算法
Mr.H01272 小时前
快速排序的常见构思
数据结构·算法
mit6.8242 小时前
背包dp|格雷码
算法