亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實(shí)現(xiàn)LeetCode(77.Combinations 組合項(xiàng))

 更新時(shí)間:2021年07月17日 14:34:18   作者:Grandyang  
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(Combinations 組合項(xiàng)),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 77.Combinations 組合項(xiàng)

Given two integers n and k, return all possible combinations of k numbers out of 1 ... n.

For example,
If n = 4 and k = 2, a solution is:

[
[2,4],
[3,4],
[2,3],
[1,2],
[1,3],
[1,4],
]

這道題讓求1到n共n個(gè)數(shù)字里k個(gè)數(shù)的組合數(shù)的所有情況,還是要用深度優(yōu)先搜索DFS來解,根據(jù)以往的經(jīng)驗(yàn),像這種要求出所有結(jié)果的集合,一般都是用DFS調(diào)用遞歸來解。那么我們建立一個(gè)保存最終結(jié)果的大集合res,還要定義一個(gè)保存每一個(gè)組合的小集合out,每次放一個(gè)數(shù)到out里,如果out里數(shù)個(gè)數(shù)到了k個(gè),則把out保存到最終結(jié)果中,否則在下一層中繼續(xù)調(diào)用遞歸??蓪懗龃a如下:

解法一:

class Solution {
public:
    vector<vector<int>> combine(int n, int k) {
        vector<vector<int>> res;
        vector<int> out;
        helper(n, k, 1, out, res);
        return res;
    }
    void helper(int n, int k, int level, vector<int>& out, vector<vector<int>>& res) {
        if (out.size() == k) {res.push_back(out); return;}
        for (int i = level; i <= n; ++i) {
            out.push_back(i);
            helper(n, k, i + 1, out, res);
            out.pop_back();
        }
    }
};

對(duì)于n = 5, k = 3, 處理的結(jié)果如下:

1 2 3
1 2 4
1 2 5
1 3 4
1 3 5
1 4 5
2 3 4
2 3 5
2 4 5
3 4 5

我們?cè)賮砜匆环N遞歸的寫法,此解法沒用helper當(dāng)遞歸函數(shù),而是把本身就當(dāng)作了遞歸函數(shù),寫起來十分的簡(jiǎn)潔,也是非常有趣的一種解法。這個(gè)解法用到了一個(gè)重要的性質(zhì) C(n, k) = C(n-1, k-1) + C(n-1, k),這應(yīng)該在我們高中時(shí)候?qū)W排列組合的時(shí)候?qū)W過吧,博主也記不清了??傊?,翻譯一下就是,在n個(gè)數(shù)中取k個(gè)數(shù)的組合項(xiàng)個(gè)數(shù),等于在n-1個(gè)數(shù)中取k-1個(gè)數(shù)的組合項(xiàng)個(gè)數(shù)再加上在n-1個(gè)數(shù)中取k個(gè)數(shù)的組合項(xiàng)個(gè)數(shù)之和。這里博主就不證明了,因?yàn)槲乙膊粫?huì),就直接舉題目中的例子來說明吧:

C(4, 2) = C(3, 1) + C(3, 2)

我們不難寫出 C(3, 1) 的所有情況:[1], [2], [3],還有 C(3, 2) 的所有情況:[1, 2], [1, 3], [2, 3]。我們發(fā)現(xiàn)二者加起來為6,正好是 C(4, 2) 的個(gè)數(shù)之和。但是我們仔細(xì)看會(huì)發(fā)現(xiàn),C(3, 2)的所有情況包含在 C(4, 2) 之中,但是 C(3, 1) 的每種情況只有一個(gè)數(shù)字,而我們需要的結(jié)果k=2,其實(shí)很好辦,每種情況后面都加上4,于是變成了:[1, 4], [2, 4], [3, 4],加上C(3, 2) 的所有情況:[1, 2], [1, 3], [2, 3],正好就得到了 n=4, k=2 的所有情況了。參見代碼如下:

解法二:

class Solution {
public:
    vector<vector<int>> combine(int n, int k) {
        if (k > n || k < 0) return {};
        if (k == 0) return {{}};
        vector<vector<int>> res = combine(n - 1, k - 1);
        for (auto &a : res) a.push_back(n);
        for (auto &a : combine(n - 1, k)) res.push_back(a);
        return res;
    }
};

我們?cè)賮砜匆环N迭代的寫法,也是一種比較巧妙的方法。這里每次先遞增最右邊的數(shù)字,存入結(jié)果res中,當(dāng)右邊的數(shù)字超過了n,則增加其左邊的數(shù)字,然后將當(dāng)前數(shù)組賦值為左邊的數(shù)字,再逐個(gè)遞增,直到最左邊的數(shù)字也超過了n,停止循環(huán)。對(duì)于n=4, k=2時(shí),遍歷的順序如下所示:

0 0 #initialization
1 0
1 1
1 2 #push_back
1 3 #push_back
1 4 #push_back
1 5
2 5
2 2
2 3 #push_back
2 4 #push_back
...
3 4 #push_back
3 5
4 5
4 4
4 5
5 5 #stop 

解法三:

class Solution {
public:
    vector<vector<int>> combine(int n, int k) {
        vector<vector<int>> res;
        vector<int> out(k, 0);
        int i = 0;
        while (i >= 0) {
            ++out[i];
            if (out[i] > n) --i;
            else if (i == k - 1) res.push_back(out);
            else {
                ++i;
                out[i] = out[i - 1];
            }
        }
        return res;
    }
};

到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(Combinations 組合項(xiàng))的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)Combinations 組合項(xiàng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Matlab繪制花里胡哨的山脊圖

    Matlab繪制花里胡哨的山脊圖

    這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)繪制一些花里胡哨的山脊圖,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定的幫助,需要的可以參考一下
    2023-02-02
  • C語言實(shí)現(xiàn)簡(jiǎn)單彈跳球游戲

    C語言實(shí)現(xiàn)簡(jiǎn)單彈跳球游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡(jiǎn)單彈跳球游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • C++泛型編程基本概念詳解

    C++泛型編程基本概念詳解

    這一篇介紹一下 C++ 編程中與面向?qū)ο蟛⒘械牧硪淮蠓种А盒途幊?,這一篇主要介紹函數(shù)模板、類模板和成員模板三大部分,需要的朋友可以參考下
    2021-08-08
  • 從C語言過渡到C++之const

    從C語言過渡到C++之const

    C++中最早引入const是為了替代#define,后來又衍生出了其它用法。這一篇中我們來詳細(xì)介紹const的各種常見用法。希望對(duì)大家學(xué)習(xí)C++有所幫助。
    2017-07-07
  • C++使用UDP通訊的實(shí)現(xiàn)示例

    C++使用UDP通訊的實(shí)現(xiàn)示例

    本文實(shí)現(xiàn)對(duì)C++使用UDP做了簡(jiǎn)單封裝,實(shí)現(xiàn)通訊,包括服務(wù)端和客戶端,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • C++ 中const 類型限定符不兼容問題

    C++ 中const 類型限定符不兼容問題

    這篇文章主要介紹了C++ 中const 類型限定符不兼容問題的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C語言實(shí)現(xiàn)三子棋的步驟和代碼詳解

    C語言實(shí)現(xiàn)三子棋的步驟和代碼詳解

    這篇文章主要介紹了C語言實(shí)現(xiàn)三子棋的步驟和代碼詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • C語言詳解函數(shù)與指針的使用

    C語言詳解函數(shù)與指針的使用

    C語言這門課程在計(jì)算機(jī)的基礎(chǔ)教學(xué)中一直占有比較重要的地位,然而要想突破C語言的學(xué)習(xí),對(duì)函數(shù)和指針的掌握是非常重要的,本文將具體針對(duì)函數(shù)和指針的關(guān)系做詳盡的介紹
    2022-04-04
  • vscode調(diào)試gstreamer源碼的詳細(xì)流程

    vscode調(diào)試gstreamer源碼的詳細(xì)流程

    在本文中主要介紹了如何使用vscode調(diào)試C++和python程序,并進(jìn)一步分析了如何調(diào)試gstreamer源碼,講述了如何調(diào)試gstreamer源碼的具體流程,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • MFC繪制不規(guī)則窗體的方法

    MFC繪制不規(guī)則窗體的方法

    這篇文章主要介紹了MFC繪制不規(guī)則窗體的方法,涉及MFC窗體操作的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05

最新評(píng)論