# Leetcode Combinations #### 2022-07-19 20:09 > ##### Algorithms: > > #algorithm #backtrack > > ##### Difficulty: > > #coding_problem #difficulty_medium > > ##### Additional tags: > > #leetcode #CS_list_need_understanding > > ##### Revisions: > > N/A ##### Related topics: ##### Links: - [Link to problem](https://leetcode.com/problems/combinations/) - [Explanation](https://leetcode.com/problems/combinations/discuss/844096/Backtracking-cheatsheet-%2B-simple-solution) --- ### Problem Given two integers `n` and `k`, return _all possible combinations of_ `k` _numbers out of the range_ `[1, n]`. You may return the answer in **any order**. #### Examples **Example 1:** ``` **Input:** n = 4, k = 2 **Output:** [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4], ] ``` **Example 2:** ``` **Input:** n = 1, k = 1 **Output:** [[1]] ``` #### Constraints **Constraints:** - `1 <= n <= 20` - `1 <= k <= n` ### Thoughts > [!summary] > This is a #backtrack problem The link I mentioned on the links section already have a good explanation on the topic. In my eyes, backtracking means DFS-like recursion and searching in solving problems. First, it add a option in the combinations, then backtrack it And when it's done, it gets poped out and try another solution, and backtrack. ### Solution Backtracking ```cpp class Solution { void backtrack(vector> &ans, vector &combs, int n, int nex, int k) { if (k == 0) { ans.push_back(combs); } else { // try different solutions for (int i = nex; i <= n; i++) { combs.push_back(i); backtrack(ans, combs, n, i + 1, k - 1); combs.pop_back(); } } } public: vector> combine(int n, int k) { vector> ans = {}; vector combs = {}; backtrack(ans, combs, n, 1, k); return ans; } }; ```