码迷,mamicode.com
首页 > 编程语言 > 详细

LeetCode算法题python解法:17. Letter Combinations of a Phone Number

时间:2018-09-03 19:30:13      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:ber   like   个数   自动   def   map   ike   ica   else   

题目:

Given a string containing digits from 2-9 inclusive, return all possible letter combinations that the number could represent.

A mapping of digit to letters (just like on the telephone buttons) is given below. Note that 1 does not map to any letters.

技术分享图片

Example:

Input: "23"
Output: ["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].

Note:

Although the above answer is in lexicographical order, your answer could be in any order you want.

这道题翻译成中文其实比较简单,就是给你数字,让你输出数字映射的字母所有可能出现的组合情况。同一个数字映射的字母不会组合到一起,不区分字母顺序,每个字母组合必须包含所有数字映射的一个字母。

这里利用递归可以轻松解决,刚好最近看了一些生成器相关的资料,索性利用递归生成器,更加简洁方便一些。

代码如下:

 1 class Solution:
 2     def letterCombinations(self, digits):
 3         return list(self.recur(digits))     
4 def recur(self, x): #由于LeetCode验证代码时不会自动将生成器转化为列表,所以只能生成器写在外面,主函数只打印答案 5 dic = {2: abc, 3: def, 4: ghi, 5: jkl, 6: mno, 7: pqrs, 8: tuv, 9: wxyz} 6 if len(x) == 0: #将digits为空值拿出来特别处理 7 return [] 8 for i in dic[x[0]]: 9 if len(x) == 1: #递归到digits只剩最后一个值挨个生成该值的映射 10 yield i 11 else: 12 for j in self.letterCombinations(x[1:]): #这里返回的生成器,可以用来迭代 13 yield i + j #拼接字符串,一层一层向上返还

 

LeetCode算法题python解法:17. Letter Combinations of a Phone Number

标签:ber   like   个数   自动   def   map   ike   ica   else   

原文地址:https://www.cnblogs.com/slarker/p/9579960.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!