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

算法训练营day22, 回溯2

216. 组合总和 III

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

  //存储全部集合

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

  //存储单次集合

  path := make([]int, 0)

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

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

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

    if len(path) == k {

      if sum == n {

        temp := make([]int, k)

        copy(temp, path)

        result = append(result, temp)

        return

      }

    }

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

      if sum+i > n { // 剪枝

        break

      }

      sum += i

      path = append(path, i)

      backtrace(k, n, sum, i+1)

      //回溯处理

      sum -= i

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

    }

  }

  backtrace(k, n, 0, 1)

  return result

}

17. 电话号码的字母组合

func letterCombinations(digits string) []string {

  result := make([]string, 0)

  if len(digits) == 0 {

    return result

  }

  letterMap := make(map[int]string, 0)

  letterMap[0] = ""

  letterMap[1] = ""

  letterMap[2] = "abc"

  letterMap[3] = "def"

  letterMap[4] = "ghi"

  letterMap[5] = "jkl"

  letterMap[6] = "mno"

  letterMap[7] = "pqrs"

  letterMap[8] = "tuv"

  letterMap[9] = "wxyz"

  //存储单次集合

  path := make([]byte, 0)

  var backtrace func(digits string, index int)

  backtrace = func(digits string, index int) {

    if index == len(digits) {

      temp := string(path)

      result = append(result, temp)

      return

    }

    //转换为int

    digit := int(digits[index] - '0')

    letter := letterMap[digit]

    for i := 0; i < len(letter); i++ {

      path = append(path, letter[i])

      backtrace(digits, index+1)

      //回溯处理

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

    }

  }

  backtrace(digits, 0)

  return result

}

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

相关文章:

  • undefined symbol: avio_protocol_get_class, version LIBAVFORMAT_58
  • Android简单支持项目符号的EditText
  • 【axios报错异常】: Uncaught ReferenceError: axios is not defined
  • Docker基础与持续集成
  • flutter开发实战-ijkplayer视频播放器功能
  • SpringFramework实战指南(五)
  • 力扣 121. 买卖股票的最佳时机
  • 【STM32+HAL库+CubeMX】UART轮询收发、中断收发、DMA收发方法及空闲中断详解
  • 基于Java医院管理系统设计与实现(源码+部署文档)
  • PHP://filter过滤器
  • 蓝桥杯刷题day05——2023
  • 【51单片机】开发板和单片机的介绍(2)
  • 《剑指 Offer》专项突破版 - 面试题 30 和 31:详解如何设计哈希表以及利用哈希表设计更加高级、复杂的数据结构
  • 回顾2023年及过去五年的成长经历
  • 99例电气实物接线及52个自动化机械手动图
  • SQL中聚合函数
  • 深度学习预备知识1——数据操作
  • 【云原生运维问题记录】kubesphere登录不跳转问题
  • 深入学习Prometheus! 一款开源的监控和警报工具!
  • 【webrtc】跟webrtc学list遍历
  • 网络安全产品之准入控制系统
  • 为什么免费ip代理不适用于分布式爬虫?
  • 【HTML 基础】元数据 meta 标签
  • 考研中常见的算法-逆置
  • docker exec命令流程
  • 游戏中好胜心的强化作用及其影响
  • 备战蓝桥杯---搜索(应用入门)
  • 自学PyQt6杂记索引
  • 【Docker】Docker Registry(镜像仓库)
  • TensorFlow2实战-系列教程14:Resnet实战2