当前位置: 首页 > news >正文

算法训练营day21,回溯1

77. 组合

func combine(n int, k int) [][]int {

  //存储全部集合

  result := make([][]int, 0)

  //存储单次集合

  path := make([]int, 0)

  var backtrace func(n int, k int, startIndex int)

  backtrace = func(n int, k int, startIndex int) {

    //当单次集合大小和k值相等,找到本次集合,但path需要一直使用需要用temp临时存储然后赋给result

    if len(path) == k {

      temp := make([]int, k)

      copy(temp, path)

      result = append(result, temp)

      return

    }

    for i := startIndex; i <= n; i++ {

      if n-i+1 < k-len(path) { // 剪枝

        break

      }

      path = append(path, i)

      backtrace(n, k, i+1)

      //回溯处理

      path = path[:len(path)-1]

    }

  }

  backtrace(n, k, 1)

  return result

}

http://www.lryc.cn/news/293152.html

相关文章:

  • 延伸与应用(三)婚姻与经济、运动、宗教、科技与经济
  • mac上,配置bundletool,将aab转为apk
  • wangEditor v4的简单使用
  • 简单实践 java spring boot 自动配置模拟
  • BeanDefinition学习
  • ASP.NET的GridView控件中,实现同列内容合并
  • 【文本到上下文 #8】NLP中的变形金刚:解码游戏规则改变者
  • mysql主流版本5.5/5.6/5.7/8.0重置修改密码方法
  • 设计模式——备忘录模式
  • 深入理解Django与Redis的集成实践
  • Java设计模式 – 四大类型
  • 查看阿里云maven仓中某个库有哪些版本
  • 【通信系统】MIMO阵列信号来向DOA估计实现~含FOCUSS、OMP、贝叶斯学习(SBL)等稀疏重构法和常规、子空间法、空间平滑滤波法
  • 高级变量赋值和变量的间接引用
  • vue动态修改侧边菜单栏宽度
  • 【C++入门到精通】C++的IO流(输入输出流) [ C++入门 ]
  • 【Spark系列5】Dataframe下常用算子API
  • 【大数据】Flink SQL 语法篇(二):WITH、SELECT WHERE、SELECT DISTINCT
  • leetcode-链表专题
  • Vue打包Webpack源码及物理路径泄漏问题解决
  • MySQL学习记录——일 MySQL 安装、配置
  • 获取真实 IP 地址(二):绕过 CDN(附链接)
  • 正则表达式补充以及sed
  • LLM智能体开发指南
  • 基于springboot校园二手书交易管理系统源码和论文
  • Oracle和Mysql数据库
  • java学习笔记:java常见注解语句汇总、解析及应用
  • k8s Sidecar filebeat 收集容器中的trace日志和app日志
  • 三维模型设计新纪元:3D开发工具HOOPS在机械加工行业的应用与优势
  • Python爬虫子页面并写入text代码