国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

LeetCode 39題:組合總和

這篇具有很好參考價(jià)值的文章主要介紹了LeetCode 39題:組合總和。希望對大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

目錄

題目

代碼

官方提供


題目

給定一個(gè)候選人編號(hào)的集合?candidates?和一個(gè)目標(biāo)數(shù)?target?,找出?candidates?中所有可以使數(shù)字和為?target?的組合。

candidates?中的每個(gè)數(shù)字在每個(gè)組合中只能使用?一次?。

注意:解集不能包含重復(fù)的組合。?

示例?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

代碼

#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;
}

官方提供

嘗試用「搜索回溯」的方法來解決。當(dāng)然,搜索回溯的過程一定存在一些優(yōu)秀的剪枝方法來使得程序運(yùn)行得更快,而這里只給出了最樸素不含剪枝的寫法

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);
? ? // 選擇當(dāng)前數(shù)
? ? 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)文章來源地址http://www.zghlxwxcb.cn/news/detail-654681.html

?

?

到了這里,關(guān)于LeetCode 39題:組合總和的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • LeetCode 39. 組合總和(回溯+剪枝)

    鏈接:LeetCode 39. 組合總和 難度:中等 給你一個(gè) 無重復(fù)元素 的整數(shù)數(shù)組 candidates 和一個(gè)目標(biāo)整數(shù) target ,找出 candidates 中可以使數(shù)字和為目標(biāo)數(shù) target 的 所有 不同組合 ,并以列表形式返回。你可以按 任意順序 返回這些組合。 candidates 中的 同一個(gè) 數(shù)字可以 無限制重復(fù)被選

    2024年02月14日
    瀏覽(22)
  • LeetCode(力扣)39. 組合總和Python

    LeetCode(力扣)39. 組合總和Python

    https://leetcode.cn/problems/combination-sum/description/

    2024年02月09日
    瀏覽(16)
  • 【算法與數(shù)據(jù)結(jié)構(gòu)】112、LeetCode路徑總和

    【算法與數(shù)據(jù)結(jié)構(gòu)】112、LeetCode路徑總和

    所有的LeetCode題解索引,可以看這篇文章——【算法和數(shù)據(jù)結(jié)構(gòu)】LeetCode題解。 ?? 思路分析 :本題通過計(jì)算根節(jié)點(diǎn)到葉子節(jié)點(diǎn)路徑上節(jié)點(diǎn)的值之和,然后再對比目標(biāo)值。利用文章【算法和數(shù)據(jù)結(jié)構(gòu)】257、LeetCode二叉樹的所有路徑中的遞歸算法。 這里要注意,默認(rèn)路徑之和是

    2024年02月11日
    瀏覽(28)
  • leetcode216. 組合總和 III(回溯算法-java)

    leetcode216. 組合總和 III(回溯算法-java)

    來源:力扣(LeetCode) 鏈接:https://leetcode.cn/problems/combination-sum-iii 找出所有相加之和為 n 的 k 個(gè)數(shù)的組合,且滿足下列條件: 只使用數(shù)字1到9 每個(gè)數(shù)字 最多使用一次 返回 所有可能的有效組合的列表 。該列表不能包含相同的組合兩次,組合可以以任何順序返回。 示例 1: 輸

    2024年02月10日
    瀏覽(20)
  • 【數(shù)據(jù)結(jié)構(gòu)】回溯算法公式化解題 leetcode經(jīng)典題目帶刷:全排列、組合、子集

    【數(shù)據(jù)結(jié)構(gòu)】回溯算法公式化解題 leetcode經(jīng)典題目帶刷:全排列、組合、子集

    一、什么是回溯算法 回溯算法(Backtracking Algorithm)是一種解決 組合問題 、 排列問題 、 選擇問題 等一類問題的常用算法。它通過嘗試所有可能的選擇來找到問題的解,當(dāng)發(fā)現(xiàn)當(dāng)前選擇不符合要求時(shí),就回溯到之前的狀態(tài),然后嘗試其他的選擇。 1、基本思想: 從問題的起

    2024年02月11日
    瀏覽(35)
  • LeetCode 377. 組合總和 Ⅳ

    LeetCode 377. 組合總和 Ⅳ

    解題思路 之前一直以為這是背包問題,后來發(fā)現(xiàn),這個(gè)是有順序的, 而背包問題是無序的,但是我們也可以用dp分析法來分析。 相關(guān)代碼

    2024年04月12日
    瀏覽(22)
  • 【Leetcode】377. 組合總和 Ⅳ

    【Leetcode】377. 組合總和 Ⅳ

    題目鏈接?? 給你一個(gè)由 不同 整數(shù)組成的數(shù)組 n u m s nums n u m s ,和一個(gè)目標(biāo)整數(shù) t a r g e t target t a r g e t 。請你從 n u m s nums n u m s 中找出并返回總和為 t a r g e t target t a r g e t 的元素組合的個(gè)數(shù)。 題目數(shù)據(jù)保證答案符合 32 32 32 位整數(shù)范圍。 示例 1: **輸入:**nums = [1,2,3],

    2024年04月23日
    瀏覽(24)
  • LeetCode-216-組合總和Ⅱ

    題目鏈接: LeetCode-216-組合總和Ⅱ 解題思路:回溯算法 注意事項(xiàng)注釋中有 代碼實(shí)現(xiàn):

    2024年02月09日
    瀏覽(20)
  • 40. 組合總和 II - 力扣(LeetCode)

    40. 組合總和 II - 力扣(LeetCode)

    題目描述 給定一個(gè)候選人編號(hào)的集合 candidates 和一個(gè)目標(biāo)數(shù) target ,找出 candidates 中所有可以使數(shù)字和為 target 的組合。 candidates 中的每個(gè)數(shù)字在每個(gè)組合中只能使用 一次 。 注意:解集不能包含重復(fù)的組合。 輸入示例 輸出示例 解題代碼

    2024年01月23日
    瀏覽(22)
  • 【LeetCode:216. 組合總和 III + 遞歸】

    【LeetCode:216. 組合總和 III + 遞歸】

    ?? 算法題 ?? ?? 算法刷題專欄 | 面試必備算法 | 面試高頻算法 ?? ?? 越難的東西,越要努力堅(jiān)持,因?yàn)樗哂泻芨叩膬r(jià)值,算法就是這樣? ?? 作者簡介:碩風(fēng)和煒,CSDN-Java領(lǐng)域優(yōu)質(zhì)創(chuàng)作者??,保研|國家獎(jiǎng)學(xué)金|高中學(xué)習(xí)JAVA|大學(xué)完善JAVA開發(fā)技術(shù)棧|面試刷題|面經(jīng)八股文

    2024年04月25日
    瀏覽(25)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包