求一个字符串的所有子序列,包含空字符串

博客介绍了打印字符串子序列的代码逻辑。通过递归方式,每次有选择或不选择当前字符两个选项,类似二叉树结构。i+1向前推进,当i达到数组长度时,打印每步选择的答案,最终二叉树叶节点即为结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

def printson(arr,i,res):
    #print(i)
    if i == len(arr):
        print(res)
        return
    printson(arr,i+1,res)
    printson(arr,i+1,res+arr[i])

if __name__ == "__main__":
    arr = "abcd"
    printson(arr,0,"")

代码解释:

比如要打印abc的子序列,每次有两个选择,选择当前字符,不选择当前字符,递归下去,相当于一颗二叉树所有的结果,i+1意味着向前进一步,最后二叉树的所有叶节点我为结果。当 i 增加到arr长度时,即打印此时每一步所选择的答案。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值