LeetCode-字典树-Easy

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步




720. Longest Word in Dictionary 词典中最长的单词

1.统计每种长度拥有的单词数量
从1位的单词开始寻找 2位长度的单词[:-1]是否包含在1位单词中 如果包含说明这个单词可以放入next中
最后将start=next 根据2位单词 找3位 直至next中没有单词
此时ret中的就是最长单词
2.排序所有words 从短到长
set中最初放入""字符
如果word[:-1]在set中 则说明这个单词满足条件 放入set
最后排序 找到len最长的单词

def longestWord(words):
    """
    :type words: List[str]
    :rtype: str
    """
    import collections
    
    value = collections.defaultdict(list)
    
    for w in words:
        value[len(w)].append(w)
        
    start = value[1]
    
    length=1
    ret = []
    while start:
        ret = start[:]
        l = value[length+1]
        next = []
        for word in l:
            if word[:length] in start:
                next.append(word)
        start = next[:]
        length+=1
    ret.sort()
    return ret[0]

def longestWord2(words):
    """
    :type words: List[str]
    :rtype: str
    """
    value = set([""])
    for word in sorted(words):
        if word[:-1] in value:
            value.add(word)
            
    return max(sorted(value),key=len)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值