代码随想录训练营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
相关推荐
未知陨落3 小时前
LeetCode:95.编辑距离
算法·leetcode
杨小码不BUG3 小时前
小鱼的数字游戏:C++实现与算法分析(洛谷P1427)
c++·算法·数组·信奥赛·csp-j/s
高山有多高3 小时前
栈:“后进先出” 的艺术,撑起程序世界的底层骨架
c语言·开发语言·数据结构·c++·算法
YouEmbedded3 小时前
解码查找算法与哈希表
数据结构·算法·二分查找·散列表·散列查找·线性查找
greentea_20134 小时前
Codeforces Round 65 C. Round Table Knights(71)
c语言·开发语言·算法
小秋学嵌入式-不读研版4 小时前
C61-结构体数组
c语言·开发语言·数据结构·笔记·算法
可触的未来,发芽的智生4 小时前
触摸未来2025.10.04:当神经网络拥有了内在记忆……
人工智能·python·神经网络·算法·架构
与己斗其乐无穷4 小时前
刷题记录(11)map和set的简单使用
算法
夜月yeyue5 小时前
个人写HTOS移植shell
c++·mcu·算法·性能优化·架构·mfc
Nix Lockhart5 小时前
《算法与数据结构》第七章[算法3]:图的最小生成树
c语言·数据结构·算法