DFS电话号码问题,及通用解题模板

# 1.终止条件  2.当前层处理  3.递归下一层
map = {
    2: "abc",
    3: "def",
    4: "ghi",
    5: "jkl",
    6: "mno",
    7: "pqrs",
    8: "tuv",
    9: "wxyz"
}
res = []


def phone_num(target: str, depth: int, string: str):
    '''
    type target: 输入的数字
    type depth: 深度
    rtype:返回所有组合 List[str]
    '''
    # 终止条件
    # 终止条件也可以不这么写,用切片的方式同样可以实现
    if depth+1 > len(target):
        res.append(string)
    # 这里必须加else
    else:
        # 当前层处理
        x = target[depth]
        loop = map[int(x)]
        for i in loop:
            # 开始递归
            # 用string这个参数将上一层的结果带到下一层
            phone_num(target, depth+1, string+i)


phone_num("23", 0, "")
print(res)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值