找出字符串的所有子字符串

前缀树实现,遍历字符串。把字符串中的每一个字符都视为前缀,用一个前缀树保存以每一个字符为开头的字符串(举例为‘abbc’)。然后遍历前缀树,把每个子树的每一层都作为一个字符串输出即可。

import copy
class TrieNode(object):
    def __init__(self,word):
        self.word = word
        self.dict1 = {}
str1 = 'abbc'
str1 = list(str1)
root = TrieNode(None)
def buildtree(root,word):
    if word not in root.dict1:
        obj = TrieNode(word)
        root.dict1[word]=obj
    else:
        obj = root.dict1[word]
    return obj
def findword(root,list1):
    if root.dict1:
        if root.word:
            list1.append(root.word)
        lenth = len(list1)
        for key in root.dict1:
            findword(root.dict1[key],list1)
            del list1[lenth:]
        if len(list1)>0:
            temp = copy.copy(list1)
            res.append(''.join(temp))
    else:
        list1.append(root.word)
        temp = copy.copy(list1)
        res.append(''.join(temp))
res = []
for i in range(len(str1)):
    head = root
    for j in range(i,len(str1)):
        head = buildtree(head,str1[j])
findword(root,[])
print(res)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值