Python面试高频问题:修改list中某个元素时的坑

在Python面试中经常会考这样一个题目 ,遍历列表,如果列表中有某某元素,那么将其替换成"test"。题目看似简单,其实有个坑在里面!从面试结果来看,大多数同学都会这样写:

l=["a","b","c"]

for i in l:

    if "a" == i:

        i="test"

print (l)

运行后,大家会发现输出的l值还是['a', 'b', 'c'],会不会感到奇怪呢?我相信绝大多数同学都会认为l的值应该是['test', 'b', 'c']!这是why? 其实很简单,这里的i虽然表示的是list 中的元素,但i只是一个临时变量而已!使用i="test并没有影响到l[0]的实际值。

如果想要修改l[0]的值,我们需要这样写:

for i in range(len(l)):

    if "a" == l[i]:

        l[i]="test"

print (l)

结果会输出['test', 'b', 'c']。这里的i是list中的元素索引,当我们在代码中加入 print(i)时 ,会看到输出 0 1 2,而l[i]="test" 表示把"test"赋值给list中某个索引位置的值。

还有一种方式可以修改list中的值,就是通过枚举法,实际工作中我们可能不经常使用,具体代码如下:

for i,value in enumerate(l):

    if "b" == l[i]:

        l[i] = "test"

print (l)

输出的值是['test', 'test', 'c'],这里的 i是元素索引,value是具体的元素值。

这个题目看似简单,但确实让很多面试的同学阴沟翻船!

最后我们来简单总结一下:

for i in l 应用在只是遍历查询,不需要对list中的值进行修改的场景;

for i in range(len(l))可以应该用到对list中的值进行修改的场景。

怎么样?get到这个点了吗?原创不易,如果文章帮到了你,劳烦点赞转发!

你可能感兴趣的:(Python面试高频问题:修改list中某个元素时的坑)