代码随想录训练营Day 22|Python|Leetcode|理论基础,77. 组合

216.组合总和III

找出所有相加之和为 nk个数的组合,且满足下列条件:

  • 只使用数字1到9
  • 每个数字 最多使用一次

返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

解题思路:

本题与组合问题相似,不同在于要添加sum和targetsum判断条件。

回溯三步骤

输入参数:def traversal(k, sum, targetsum, path, result)

停止条件:if len(path) == k and sum == targetsum: result.append(path)

回溯逻辑:for i in range(1, 10), sum += i, path.append(i), traversal(k, sum, targetsum, start, path, result), sum -= i, path.pop()

python 复制代码
class Solution:
    def combinationSum3(self, k: int, n: int) -> List[List[int]]:
        path = []
        result = []
        def traversal(k, target_sum, sum, start, path, result):
            if len(path) == k and sum == target_sum:
                result.append(path[:])
            for i in range(start, 10):
                sum += i
                path.append(i)
                traversal(k, target_sum, sum, i+1, path, result)
                sum -= i
                path.pop()
        traversal(k, n, 0, 1, path, result)
        return result

17.电话号码的字母组合

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

解题思路:

设置一个字典存储digits对应的字母,设置s存储当前遍历字符result存储结果。

输入参数:def traversal(s, result, digits, index) index记录正在遍历的数字

停止条件:如果正在遍历的index超出digits长度,直接出存进result

回溯逻辑:添加进s,递归index+1,从s中删除

python 复制代码
class Solution:
    def letterCombinations(self, digits: str) -> List[str]:
        numbers = {'2':'abc', '3':'def', '4':'ghi', '5':'jkl', '6':'mno', '7':'pqrs', '8':'tuv', '9':'wxyz'}
        #the digit we are combining
        index = 0
        s = ''
        result = []
        if not digits:
            return result
        def backtracking(s, result, index, digits):
            #stopping
            if len(digits) == index:
                result.append(s)
                return 
            digit = digits[index]
            string = numbers[digit]
            for i in range(len(string)):
                s += string[i]
                backtracking(s, result, index+1, digits)
                #处理下一个数字
                s = s[:-1]
        backtracking(s, result, index,digits)
        return result
相关推荐
独自破碎E1 分钟前
【面试真题拆解】Redis的8种内存淘汰策略
redis·面试·职场和发展
迈巴赫车主2 分钟前
天梯赛 L2-004 这是二叉搜索树吗?java
java·开发语言·数据结构·算法·天梯赛
badhope11 分钟前
C语言二级考点全解析与真题精讲
c语言·开发语言·c++·人工智能·python·microsoft·职场和发展
沐苏瑶13 分钟前
Java 数据结构精讲:二叉树遍历算法与底层实现剖析
数据结构·算法
董董灿是个攻城狮40 分钟前
大模型连载8:词向量如何表示近义词?
人工智能·python·算法·机器学习
Jasmine_llq1 小时前
《B4001 [GESP202406 一级] 立方数》
算法·单输入处理·整数算术运算·立方数枚举验证算法(核心逻辑)·循环终止优化算法·状态标记算法·三元运算符输出
芸忻1 小时前
day 13 第六章 二叉树 part01代码随想录算法训练营71期
数据结构·算法
2401_900151541 小时前
C++中的桥接模式
开发语言·c++·算法
小O的算法实验室1 小时前
2026年IEEE TNSE SCI2区,基于预测的双阶段分布式任务分配方法+搜救场景中最大化任务分配,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
月流霜1 小时前
Midjourney 零基础控图七大参数
人工智能·算法·midjourney