Python中zip,与zip

目录

可以看成是zip()为压缩,zip(*)是解压

zip()

  • 返回一个以元祖为元素的列表[()],每一个元祖的元素都是取自参数序列的

  • 返回的列表长度是被压缩为最短的参数序列的长度,只是一个参数序列时,它返回一个1元祖的列表。没有参数时,返回一个空的列表。

    l1 = ['a', 'b']
    l2 = ['c', 'd']
    l3 = list(zip(l1, l2))
    print(l3)
    

    [('a', 'c'), ('b', 'd')]

    当参数长度不同的时候

    l1 = ["a", 'b',"esdasda"]
    l2 = ['c', 'd']
    l3 = list(zip(l1, l2))
    print(l3)
    

    [('a', 'c'), ('b', 'd')]

    当只有一个参数的时候

    l1 = ["a", 'b',"esdasda"]
    l3 = list(zip(l1))
    print(l3)
    

    [('a',), ('b',), ('esdasda',)]

    没有参数的时候

    ​```python
    l1 = []
    l3 = list(zip(l1))
    print(l3)
    

    []

zip(*)

  • 解包

  • 返回的每一个都是元祖类型,而并非是原来的数据类型

l1 = ['a', 'b']

l2 = ['c', 'd']

l3 = list(zip(l1, l2))

l4, l5 = list(zip(*l3))

print(l4)

print(l5)

print(type(l4))

```

('a', 'b')
('c', 'd')
<class 'tuple'>
  • 如果返回的参数只有一个,则会再打包放到一个列表中

    l1 = ['a', 'b']
    l2 = ['c', 'd']
    l3 = list(zip(l1, l2))
    l4 = list(zip(*l3))
    print(l4)
    print(type(l4))
    

    [('a', 'b'), ('c', 'd')]

    <class 'list'>

  • 如果返回的参数值与l3本身的元素个数不同,且不为1时,无法解包

    l1 = ['a', 'b']
    l2 = ['c', 'd']
    l6 = ['e', 'f']
    l3 = list(zip(l1, l2, l6))
    l4, l5 = list(zip(*l3))
    print(l4)
    print(type(l4))
    

    Traceback (most recent call last):

    File "M:/Python基础/leetcode/draft.py", line 5, in

    l4, l5 = list(zip(*l3))

    ValueError: too many values to unpack (expected 2)

知识点来自leetcode最长公共前缀

  • 题目:编写一个函数来查找字符串数组中的最长公共前缀。

    ​ 如果不存在公共前缀,返回空字符串 ""

    示例 1:

    输入: ["flower","flow","flight"]
    输出: "fl"
    

    示例 2:

    输入: ["dog","racecar","car"]
    输出: ""
    解释: 输入不存在公共前缀。
    

    说明:

    所有输入只包含小写字母 a-z

  • 还没有学到函数,所以代码未使用函数,若要放入leetcode中,将x的定义删除,print换成return即可

  • 以下为代码解析

    strs = ["flower", "flow", "flight"]
    strs_z = list(zip(*strs))    # 把strs解包,将不同元素的同一索引值放入一个个元祖中,再打包成list
    s = ""
    
    for i in strs_z:
        i = set(i)       # 利用集合的唯一性
        if len(i) == 1:
            i = str(i)
            s += i[2]   # 这样得到的i才会不带{}
        else:
            break
    print(s)
    

    fl