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

文章描述了一个编程问题,要求在给定整数n和k的条件下,生成并返回[1,n]中所有可能的k个数的组合。提供了使用深度优先搜索(DFS)的解决方案,通过递归实现。
摘要由CSDN通过智能技术生成

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
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值