8.22 - hard - 81

2017-08-22  本文已影响0人  健时总向乱中忙

411. Minimum Unique Word Abbreviation

利用比较基本的方法,backtracking找出全部的abbreviation,TLE

class Solution(object):
    def minAbbreviation(self, target, dictionary):
        """
        :type target: str
        :type dictionary: List[str]
        :rtype: str
        """
        # 基本想法是先把dict里的所有可能的变形都找出来
        # 然后再找target
        res = set()
        if dictionary:
            for word in dictionary:
                self.search(word, "", 0, 0, res)
        if not res:
            return str(len(target))
        target_set = set()
        self.search(target, "", 0, 0, target_set)
        new = target_set.difference(res)
        
        return sorted(new, key=self.cal)[0]
        
        
    def cal(self, s):
        l = 0
        first_digit = True
        for c in s:
            if first_digit and c.isdigit():
                l += 1
                first_digit = False
            if not c.isdigit():
                l += 1
                first_digit = True
        
        return l
        
    
    def search(self, s, cur, pos, count, res):
        if pos == len(s):
            if count > 0:
                cur += str(count)
            res.add(cur)
            return
        
        self.search(s, cur, pos+1, count+1, res) # 缩略当前的字母增加count
        if count > 0:
            cur = cur + str(count) + s[pos]
        else:
            cur = cur + s[pos]
        self.search(s, cur, pos+1, 0, res)

上一篇 下一篇

猜你喜欢

热点阅读