leetcode1081

Posted asenyang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode1081相关的知识,希望对你有一定的参考价值。

 1 class Solution(object):
 2     def __init__(self):
 3         self.count = 0
 4     
 5     def dfs(self, tiles, used, visited, path):
 6         
 7         if len(path) > 0 and path not in visited:
 8             visited.add(path)
 9             self.count += 1
10 
11         for i in range(len(tiles)):
12             if used[i]:
13                 continue
14             used[i] = True                            
15             self.dfs(tiles, used, visited, path + tiles[i])        
16             used[i] = False
17                 
18 
19     def numTilePossibilities(self, tiles):
20         """
21         :type tiles: str
22         :rtype: int
23         """
24 
25         visited = set()
26         used = [False] * len(tiles)        
27         self.dfs(tiles, used, visited, "")            
28         return self.count

回溯法,参考:https://leetcode.com/problems/letter-tile-possibilities/discuss/308486/Simple-python-solution-with-backtracking

 

另外一行样式:

1 class Solution:
2     def numTilePossibilities(self, tiles: str) -> int:
3         return sum(len(set(itertools.permutations(tiles, i))) for i in range(1, len(tiles) + 1))

参考:https://leetcode.com/problems/letter-tile-possibilities/discuss/308518/Python-1-liner

以上是关于leetcode1081的主要内容,如果未能解决你的问题,请参考以下文章

leetcode1081. Smallest Subsequence of Distinct Characters

1081. 不同字符的最小子序列

leetcode_1292. Maximum Side Length of a Square with Sum Less than or Equal to Threshold_[二维前缀和](代码片段

Leetcode.1024 视频拼接

PAT1081:Rational Sum

线段树模板合集(CodeVS1080 1081 1082 4597)Pascal代码