LeetCode 39题:组合总和

目录

题目

代码

官方提供


题目

给定一个候选人编号的集合 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。

candidates 中的每个数字在每个组合中只能使用 一次

**注意:**解集不能包含重复的组合。

示例 1:

输入: candidates = [10,1,2,7,6,1,5], target = 8,
输出:
[
[1,1,6],
[1,2,5],
[1,7],
[2,6]
]

示例 2:

复制代码
输入: candidates = [2,5,2,1,2], target = 5,
输出:
[
[1,2,2],
[5]
]

提示:

  • 1 <= candidates.length <= 100
  • 1 <= candidates[i] <= 50
  • 1 <= target <= 30

代码

cs 复制代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

int len=0;
int size=0;
int*columnsize;

int search(int target,int**res,int*combine,int ind,int*candidates,int candidatesSize);
int** combinationSum(int* candidates, int candidatesSize, int target, int* returnSize, int** returnColumnSizes);

int main()
{
    int candidates[4] = {2,3,5}, target = 8;
    int *returnSizes=(int*)malloc(sizeof(int)),**returnColumnSize=(int**)malloc(sizeof(int*));
    returnColumnSize[0]=(int*)malloc(sizeof(int));
    int **res=combinationSum(candidates,3,target,returnSizes,returnColumnSize);
    for(int i=0;i<*returnSizes;i++)
    {
        for(int j=0;j<returnColumnSize[0][i];j++)
        {
            printf("%d ",res[i][j]);
        }
        printf("\n");
    }
}

int** combinationSum(int* candidates, int candidatesSize, int target, int* returnSize, int** returnColumnSizes)
{
    columnsize=(int*)malloc(sizeof(int));
    int**res=(int**)malloc(sizeof(int*)*150);
    if(candidates[0]>target)
    {
        *returnSize=0;
        returnColumnSizes[0][*returnSize]=0;
        return NULL;
    }
    int*combine=(int*)malloc(sizeof(int)*(target/candidates[0]+1)); 
    int t= search(target,res,combine,0,candidates,candidatesSize);
    *returnSize=size;
    returnColumnSizes[0]=columnsize;
    return res;
}

int search(int target,int**res,int*combine,int ind,int*candidates,int candidatesSize)
{
    if(target<0)
    {
        return 1;
    }
    if(target==0)
    {
        size++;
        columnsize=(int*)realloc(columnsize,sizeof(int)*size);
        columnsize[size-1]=len;
        int *temp=(int *)malloc(sizeof(int)*len);
        for(int i=0;i<len;i++)
        {
            temp[i]=combine[i];
        }
        res[size-1]=temp;
        return 1;
    }
    else 
    {
        for(int i=ind;i<candidatesSize;i++)
        {
            combine[len++]=candidates[i];        
            int t=len;
            int sign=search(target-candidates[i],res,combine,i,candidates,candidatesSize);
            len--;
            if(sign==1)
            {
                break;
            }
        }
    }
    return 0;
}

官方提供

尝试用「搜索回溯」的方法来解决。当然,搜索回溯的过程一定存在一些优秀的剪枝方法来使得程序运行得更快,而这里只给出了最朴素不含剪枝的写法

cs 复制代码
int candidatesSize_tmp;

int ansSize;

int combineSize;

int* ansColumnSize;

void dfs(int* candidates, int target, int** ans, int* combine, int idx) {
    if (idx == candidatesSize_tmp) {
        return;
    }
    if (target == 0) {
        int* tmp = malloc(sizeof(int) * combineSize);
        for (int i = 0; i < combineSize; ++i) {
            tmp[i] = combine[i];
        }
        ans[ansSize] = tmp;
        ansColumnSize[ansSize++] = combineSize;
        return;
    }
    // 直接跳过
    dfs(candidates, target, ans, combine, idx + 1);
    // 选择当前数
    if (target - candidates[idx] >= 0) {
        combine[combineSize++] = candidates[idx];
        dfs(candidates, target - candidates[idx], ans, combine, idx);
        combineSize--;
    }
}

int** combinationSum(int* candidates, int candidatesSize, int target, int* returnSize, int** returnColumnSizes) {
    candidatesSize_tmp = candidatesSize;
    ansSize = combineSize = 0;
    int** ans = malloc(sizeof(int*) * 1001);
    ansColumnSize = malloc(sizeof(int) * 1001);
    int combine[2001];
    dfs(candidates, target, ans, combine, 0);
    *returnSize = ansSize;
    *returnColumnSizes = ansColumnSize;
    return ans;
}

作者:力扣官方题解

链接:https://leetcode.cn/problems/combination-sum/solutions/406516/zu-he-zong-he-by-leetcode-solution/

来源:力扣(LeetCode)

相关推荐
梅茜Mercy36 分钟前
数据结构:链表(经典算法例题)详解
数据结构·链表
88号技师39 分钟前
2024年12月一区SCI-加权平均优化算法Weighted average algorithm-附Matlab免费代码
人工智能·算法·matlab·优化算法
IT猿手39 分钟前
多目标应用(一):多目标麋鹿优化算法(MOEHO)求解10个工程应用,提供完整MATLAB代码
开发语言·人工智能·算法·机器学习·matlab
青春男大40 分钟前
java栈--数据结构
java·开发语言·数据结构·学习·eclipse
88号技师40 分钟前
几款性能优秀的差分进化算法DE(SaDE、JADE,SHADE,LSHADE、LSHADE_SPACMA、LSHADE_EpSin)-附Matlab免费代码
开发语言·人工智能·算法·matlab·优化算法
Zer0_on43 分钟前
数据结构栈和队列
c语言·开发语言·数据结构
一只小bit43 分钟前
数据结构之栈,队列,树
c语言·开发语言·数据结构·c++
我要学编程(ಥ_ಥ)1 小时前
一文详解“二叉树中的深搜“在算法中的应用
java·数据结构·算法·leetcode·深度优先
埃菲尔铁塔_CV算法1 小时前
FTT变换Matlab代码解释及应用场景
算法
许野平2 小时前
Rust: enum 和 i32 的区别和互换
python·算法·rust·enum·i32