python列表推导式及其简单应用

  列表推导式(又称列表解析式)提供了一种简明扼要的方法来创建列表

  一个简单平方

  普通for循环

  for i in range(1,5):

  print(i*i,end='')

  列表推导式

  res = [x*x for x in range(1,5)]

  print(res)

  执行顺序

  [x*y for x in range(1,5) if x > 2 for y in range(1,4) if y < 3]

  等价于

  for x in range(1,5):

  if x > 2:

  for y in range(1,4):

  if y < 3:

  return x*y

  leetcode17电话号码的字母组合

  给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。

  给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

  这题看起来递归比较合适,但是强行循环也不是不可以

  class Solution:

  def letterCombinations(self, digits):

  m = {

  '2': list('abc'),

  '3': list('def'),

  '4': list('ghi'),

  '5': list('jkl'),

  '6': list('mno'),

  '7': list('pqrs'),

  '8': list('tuv'),

  '9': list('wxyz'),

  }

  if not digits:

  return []

  res = ['']

  for i in digits:

  res = [x + y for x in res for y in m[i]]

  return res

  这里的循环其实不止两层,取决于你输入的数字的位数。可以打印输出看一下,假设输入的数字是234

  ['a', 'b', 'c']

  ['ad', 'ae', 'af', 'bd', 'be', 'bf', 'cd', 'ce', 'cf']郑州人流多少钱 http://mobile.sgyy029.com/

  ['adg', 'adh', 'adi', 'aeg', 'aeh', 'aei', 'afg', 'afh', 'afi', 'bdg', 'bdh', 'bdi', 'beg', 'beh', 'bei', 'bfg', 'bfh', 'bfi', 'cdg', 'cdh', 'cdi', 'ceg', 'ceh', 'cei', 'cfg', 'cfh', 'cfi']

  第一个2对应的字母是[‘a’, ‘b’, ‘c’]

  第二个3对于的字母是[‘d’, ‘e’, ‘f’]

  第三个4对于的字母是[‘g’, ‘h’, ‘i’]

  开始的时候res长度为1,可以理解为

  res = ['']

  m = ['a', 'b', 'c']

  for x in res:

  tem = []

  for y in m:

  res = x + y

  tem.append(res)

  print(tem)

  当有两个数字时

  res = ['']

  m = ['a', 'b', 'c']

  n = ['d', 'e', 'f']

  tem = []

  for x in res:

  for y in m:

  for k in n:

  res = x + y + k

  tem.append(res)

  print(tem)

  这样一层一层加下去就可以,不过即使知道要循环几次,也很难表达出来,这个时候用列表推导式就很方便

posted @ 2019-12-05 11:09  tiana_Z  阅读(373)  评论(0编辑  收藏  举报