zoukankan      html  css  js  c++  java
  • [LeetCode] Combinations

    A typical backtracking problem. For any backtracking problem, you need to be think about three ascepts:

    1. What is a partial solution and when is it finished? --- In this problem, the partial solution is a combination (sol). It is finished once it contains k elements.
    2. How to find all the partial solutions? --- In the following code, I simply traverse all the possible starting elements (start).
    3. When to make recursive calls? --- In the following code, once an element is added to the partial solution, we call the function to generate the remaining elements recursively.

    Of course, remember to recover to the previous status once a partial solution is done. In the following code, line 18 (sol.pop_back()) is for this purpose.

    The following should be self-explanatory :)

     1 class Solution {
     2 public:
     3     vector<vector<int>> combine(int n, int k) {
     4         vector<vector<int> > res;
     5         vector<int> sol;
     6         combination(1, n, k, sol, res);
     7         return res;
     8     }
     9 private:
    10     void combination(int start, int n, int k, vector<int>& sol, vector<vector<int> >& res) {
    11         if (k == 0) {
    12             res.push_back(sol);
    13             return;
    14         }
    15         for (int i = start; i <= n; i++) {
    16             sol.push_back(i);
    17             combination(i + 1, n, k - 1, sol, res);
    18             sol.pop_back();
    19         }
    20     }
    21 };
  • 相关阅读:
    Shell脚本最佳实践
    tmux会话断电保存自动恢复
    [JD15] 括号匹配方案
    [LeetCode 187.] 重复的DNA序列
    [LeetCode 162.] 寻找峰值
    基于 Chocolatey 打造 Windows 开发环境
    [LeetCode 71.] 简化路径 【IO】
    【栈】栈排序
    [LeetCode 829.] 连续整数求和
    [LeetCode 29.] 两数相除
  • 原文地址:https://www.cnblogs.com/jcliBlogger/p/4582166.html
Copyright © 2011-2022 走看看