代码随想录算法训练营第24天|● 理论基础 ● 77. 组合

77. 组合

已解答
中等
相关标签
相关企业
给定两个整数 n 和 k,返回范围 [1, n] 中所有可能的 k 个数的组合。
你可以按 任何顺序 返回答案。

示例 1:
输入:n = 4, k = 2
输出:
[
[2,4],
[3,4],
[2,3],
[1,2],
[1,3],
[1,4],
]
示例 2:
输入:n = 1, k = 1
输出:[[1]]

提示:

  • 1 <= n <= 20
  • 1 <= k <= n

代码

func combine(n int, k int) [][]int {
   
   tmp, res := make([]int, 0), make([][]int, 0)
   dfs(n, k, 1, tmp, &res)
   return res
}

func dfs(n int, k int, startindex int, combine []int, res *[][]int) {
   
   if len(combine) == k {
   
      tmp := make([]int, len(combine))
      copy(tmp, combine)
      *res = append(*res, tmp)
      return
   }

   for i := startindex; i <= n; i++ {
   
      combine = append(combine, i)
      dfs(n, k, i+1, combine, res)
      combine = combine[:len(combine)-1]
   }
   return
}

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-07 19:54:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-07 19:54:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-07 19:54:02       82 阅读
  4. Python语言-面向对象

    2023-12-07 19:54:02       91 阅读

热门阅读

  1. 《算法通关村——滑动窗口高频问题》

    2023-12-07 19:54:02       63 阅读
  2. vue实现父子传参

    2023-12-07 19:54:02       59 阅读
  3. 【Android】Retrofit创建实例源理

    2023-12-07 19:54:02       41 阅读
  4. 26.Oracle11g的数据装载

    2023-12-07 19:54:02       61 阅读
  5. Node.js 的 os 模块介绍

    2023-12-07 19:54:02       51 阅读
  6. Django回顾5

    2023-12-07 19:54:02       38 阅读
  7. docker安装达梦数据库并挂在数据卷

    2023-12-07 19:54:02       64 阅读
  8. HTTPS:保护网络通信安全的关键

    2023-12-07 19:54:02       61 阅读
  9. linux中xarray结构简析

    2023-12-07 19:54:02       63 阅读