Python代码阅读(第13篇):检测列表中的元素是否都一样

Posted Felix

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python代码阅读(第13篇):检测列表中的元素是否都一样相关的知识,希望对你有一定的参考价值。

Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码

本篇阅读的代码实现了检测列表中的元素是否都一样的逻辑。

本篇阅读的代码片段来自于30-seconds-of-python

all_equal

def all_equal(lst):
  return lst[1:] == lst[:-1]

# EXAMPLES
all_equal([1, 2, 3, 4, 5, 6]) # False
all_equal([1, 1, 1, 1]) # True

all_equal函数接收一个列表,并判断列表中的各个元素是否都一样,如果一样就返回True否则返回false

该函数采用的判断方式比较巧妙,将原列表去除第一个元素之后的子列表和原列表去除最后一个元素子列表进行对比。也就是原列表的元素进行了错位比较,元素从头到尾依次进行比较。

[a[0], a[1], ... a[n-1]] == [a[1], a[2], ... a[n]]
a[0] == a[1], a[1] == a[2], ... a[n-1] == a[n]
a[0] == a[1] == a[2] ... a[n-1] == a[n]

列表切片

lst[1:]lst[:-1]是列表切片的形式。lst[1:]表示从列表lst下标为1的元素开始一直到列表lst最后一个元素的子列表。lst[:-1]则是从第一个元素(下标为0)开始直至列表的倒数第二个元素。

一般而言列表切片的形式是lst[a:b]ab代表了列表的索引。lst[a:b]返回的子列表从索引a开始,直到索引b的前一个元素停止。省略a或者b代表了“从头开始”或“直到列表结尾”。lst[:]会返回整个列表的切片。负数索引返回离列表末尾相应距离的元素,-1指的是列表最后一个元素。

Python代码阅读(第40篇):通过两个列表生成字典

Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码

本篇阅读的代码实现了使用两个列表中的元素分别作为keyvalue生成字典。

本篇阅读的代码片段来自于30-seconds-of-python

to_dictionary

def to_dictionary(keys, values):
  return {key:value for key, value in zip(keys, values)}

# EXAMPLES
to_dictionary([\'a\', \'b\'], [1, 2]) # { a: 1, b: 2 }

to_dictionary函数接收两个列表作为keyvalue,返回由这两个列表的元素组成的字典。

函数使用字典推导式生成新的字典,使用列表key中的元素作为字典的键,使用列表value中对应的元素作为对应的值。推导式使用zip函数同时迭代两个列表,获取两个列表中相对应的元素。

zip(*iterables)创建一个聚合了来自每个可迭代对象中的元素的迭代器。它返回一个元组的迭代器,其中的第i个元组包含来自每个参数序列或可迭代对象的第i个元素。 当所输入可迭代对象中最短的一个被耗尽时,迭代器将停止迭代。 当只有一个可迭代对象参数时,它将返回一个单元组的迭代器。不带参数时,它将返回一个空迭代器。

>>> x = [1, 2, 3]
>>> y = [4, 5, 6]
>>> zipped = zip(x, y)
>>> list(zipped)
[(1, 4), (2, 5), (3, 6)]

以上是关于Python代码阅读(第13篇):检测列表中的元素是否都一样的主要内容,如果未能解决你的问题,请参考以下文章

Python代码阅读(第25篇):将多行字符串拆分成列表

Python代码阅读(第26篇):将列表映射成字典

Python代码阅读(第41篇):矩阵转置

Python入门教程第38篇 filter()函数

Python入门教程第40篇 列表推导式

Python入门教程第28篇 列表