赞
踩
map()
函数是Python
的内置函数,会根据提供的函数参数,对传入的序列数据进行映射。
所以,map()
函数也称映射函数
。
在Python
中,map
是一个类,有着迭代方法,能够返回对应值。平时也能充当着函数使用:
print(list(map(lambda x:x[0],[[1,2],[3,4]])))
# [1, 3]
data=[[1,2],[3,4]]
A=map(lambda x:x[0],data)
for i in range(len(data)):
print(A.__next__())
# 1
# 3
最常见的格式为:
map(function,iterables,...)->map
Input
Output
我们来进行一个简单的尝试!
实例一
设计一个函数,将两个数组A
和B
中的元素加起来。
def Add(x,y):
n,m=len(x),len(y)
if n>m:
n,m=m,n
x,y=y,x
new=[i for i in y]
for i in range(n):
new[i]+=x[i]
return new
A=[1,2,3,4,5,6,7,8]
B=[1,2,3,4,5,6]
print(Add(A,B))
# [2, 4, 6, 8, 10, 12, 7, 8]
那如果对格式输入不那么严格,又想比较简便地实现操作,我们可以通过map
+lambda
表达式的方式,对输入的元素进行一一映射。
print(list(map(lambda x,y:x+y,A,B)))
# [2, 4, 6, 8, 10, 12]
此时,第一个参数是一个映射(函数),第二,第三个参数则是输入的可迭代对象。map
会自动的依次取出
可迭代对象中的每个元素,通过映射输出。我们可以通过map.__next__()
控制获取每一个元素,或是直接将返回的迭代对象转化为list
获取全部元素。
map
能够确保数据的最小截断,也就是满足两个或多个可迭代对象进行的最小长度。比如上文提到的,A
数组的长度是高于B
数组的,但由于map
对象的特性,返回值只保留到B
的长度。
是不是学会了!那我们再来看一题。
将一个元组对象转化为一个列表。
A=((7),(7),(7),(7),(7),(7),(7),(8))
print([[i] for i in A])
# 或者
print(list(map(list,A)))
实例二
出自LC417太平洋大西洋水流问题
有一个 m × n 的矩形岛屿,与 太平洋 和 大西洋 相邻。 “太平洋” 处于大陆的左边界和上边界,而 “大西洋” 处于大陆的右边界和下边界。
这个岛被分割成一个由若干方形单元格组成的网格。给定一个 m x n 的整数矩阵 heights , heights[r][c]
表示坐标 (r, c) 上单元格 高于海平面的高度 。
岛上雨水较多,如果相邻单元格的高度 小于或等于 当前单元格的高度,雨水可以直接向北、南、东、西流向相邻单元格。水可以从海洋附近的任何单元格流入海洋。
返回网格坐标 result 的 2D 列表 ,其中 result[i] = [ri, ci] 表示雨水从单元格 (ri, ci) 流动 既可流向太平洋也可流向大西洋 。
输入: heights = [[1,2,2,3,5],[3,2,3,4,4],[2,4,5,3,1],[6,7,1,4,5],[5,1,1,2,4]]
输出: [[0,4],[1,3],[1,4],[2,2],[3,0],[3,1],[4,0]]
class Solution: def pacificAtlantic(self, heights: List[List[int]]) -> List[List[int]]: m,n=len(heights),len(heights[0]) def search(start): visitSet=set() def dfs(x,y): if (x,y) in visitSet: return val=heights[x][y] visitSet.add((x,y)) for i,j in [[x+1,y],[x-1,y],[x,y-1],[x,y+1]]: if 0<=i<m and 0<=j<n and heights[i][j]>=val: dfs(i,j) for i,j in start: dfs(i,j) return visitSet pacificSet=[(0,i) for i in range(n)]+[(i,0) for i in range(m)] altanticSet=[(m-1,i) for i in range(n)]+[(i,n-1) for i in range(m)] return list(map(list,search(pacificSet)&search(altanticSet)))
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。