组合问题:为什么用start避免重复

好问题!让我详细解释"用start避免重复"的含义。

组合问题:为什么需要start?

组合的定义 :选出k个数,顺序无关

  • 1,2\] 和 \[2,1\] 是**同一个组合**

c 复制代码
// ❌ 错误:没有start限制
void dfs(int n, int k, int *path, int pathSize, ...) {
    if (pathSize == k) {
        保存path;
        return;
    }
    
    for (int i = 1; i <= n; i++) {  // 每次都从1开始
        if (!visited[i]) {
            path[pathSize] = i;
            dfs(n, k, path, pathSize+1, ...);
        }
    }
}

// n=4, k=2
// 会生成:[1,2], [2,1], [1,3], [3,1], ... 重复!

✅ 用start避免重复

c 复制代码
void dfs(int n, int k, int start, int *path, int pathSize, ...) {
    if (pathSize == k) {
        保存path;
        return;
    }
    
    for (int i = start; i <= n; i++) {  // 从start开始,不回头
        path[pathSize] = i;
        dfs(n, k, i + 1, path, pathSize+1, ...);  // 下次从i+1开始
    }
}

关键i + 1 保证后面的数字永远比前面大

图解说明

n=4, k=2,用start

复制代码
DFS树(用start):
           []
    /      |     |    \
   1       2     3     4
  /|\      |\     |
 2 3 4     3 4    4

生成:
[1,2], [1,3], [1,4]  ← 从1开始,后面只选2,3,4
[2,3], [2,4]         ← 从2开始,后面只选3,4
[3,4]                ← 从3开始,后面只选4

✅ 无重复:[2,1]不会出现,因为选了2后,start=3,不会回头选1

没有start

复制代码
DFS树(没有start):
              []
      /   /   |   \   \
     1   2    3    4
   / |\ |\  /|\ /|\
  1 234 12 123 123...

生成:
[1,2], [1,3], [1,4]
[2,1], [2,3], [2,4]  ← ❌ [2,1]是重复的
[3,1], [3,2], [3,4]  ← ❌ [3,1],[3,2]是重复的
...

总结

start的作用

  • 保证每次只从当前数字后面
  • 避免选到前面的数字
  • 自然地保证:path[0] < path[1] < path[2] < ...
  • 因此 [1,2] 会生成,但 [2,1] 不会生成

记忆

复制代码
组合:顺序无关 → 用start保证递增 → 避免重复
排列:顺序相关 → 用visited避免重用 → 允许任意顺序

这就是为什么组合用start,而全排列用visited!

相关推荐
程序员-King.4 小时前
day158—回溯—全排列(LeetCode-46)
算法·leetcode·深度优先·回溯·递归
月挽清风5 小时前
代码随想录第七天:
数据结构·c++·算法
小O的算法实验室5 小时前
2026年AEI SCI1区TOP,基于改进 IRRT*-D* 算法的森林火灾救援场景下直升机轨迹规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小郭团队5 小时前
2_1_七段式SVPWM (经典算法)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·硬件架构·arm·dsp开发
充值修改昵称5 小时前
数据结构基础:从二叉树到多叉树数据结构进阶
数据结构·python·算法
Deepoch6 小时前
Deepoc数学大模型:发动机行业的算法引擎
人工智能·算法·机器人·发动机·deepoc·发动机行业
浅念-6 小时前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
Hcoco_me6 小时前
大模型面试题84:是否了解 OpenAI 提出的Clip,它和SigLip有什么区别?为什么SigLip效果更好?
人工智能·算法·机器学习·chatgpt·机器人
BHXDML7 小时前
第九章:EM 算法
人工智能·算法·机器学习
却道天凉_好个秋8 小时前
目标检测算法与原理(三):PyTorch实现迁移学习
pytorch·算法·目标检测