一道python面试题引发的血案

时间:2021-04-30 13:57:14

  这里说的是一道阿里校招的面试题:一行代码实现对列表a中的偶数位置的元素进行加3后求和?

  今天去面试同样遇到了这个题目,这道题考察的是对python高阶函数map/filter的灵活运用(具体的使用方法可以参考‘廖雪峰的官方网站’)。作为一个小白的我对高阶函数的运用本就不多,当时连高阶函数的名字都记不清了(书到用时方恨少),妥妥的被虐了个无路可走。无奈记下题目回来求助于度娘了,没想到是阿里的校招题目,网上也给出了答案,但是很明显该答案是存在一些问题的,具体什么问题在这里就不讲了,大家可以自行查找,并找出问题所在。

  由于我已记不清列表a的模样, 所以我们先来定义一个列表 a = [2, 5, 7, 9, 34, 12]

  首先,我们要找到列表a中的偶数位置的元素, 在这里我们要用到的是filter函数( filter的具体使用方法这里就不讲了):

 r = filter(lambda u: a.index(u) % 2 == 1, a)  # 为了拿到列表中元素的index值,
                              调用list.index()。 print(list(r))                   # 结果为: [5, 9, 12]

  拿到了偶数位置的元素之后,要用到map函数对每个元素进行加3的操作:

 s = map(lambda y:y+3, list(r))
 print(list(s))                      # 结果为: [8, 12, 15]

  这样我们就对偶数位置的元素进行了加3,这里用sum函数最为简单,最后把完整的代码放上:

sum(list(map(lambda y: y+3, filter(lambda u: a.index(u) % 2 == 1, a))))   #结果:35

  上面这行代码已经可以解决问题了,另外我们还可以调用另一个高阶函数来完成求和,没错,就是reduce函数,在使用reduce函数之前,要先调用一下:

 from functools import reduce    # 当然,这违背了一行代码解决问题的初衷
2 reduce(lambda x, y: x+y, map(lambda y:y+3, filter(lambda u: a.index(u)%2 == 1, a)))    #结果:35

  好了,说到这里,这道题目就算讲完了,如果你有更简单的方法,也请在留言中列出,大家互相交流,才能共同进步。

  什么,你问我血案在哪,当然是忽略并忘记它啦!!!